在編寫Java腳本前,需確保CentOS系統已安裝JDK并正確配置環境變量??赏ㄟ^java -version
和javac -version
驗證安裝;使用YUM包管理器安裝OpenJDK(如sudo yum install java-1.8.0-openjdk-devel
),并編輯/etc/profile
或用戶目錄下的.bashrc
文件,添加以下內容:
export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk # 根據實際安裝路徑調整
export PATH=$JAVA_HOME/bin:$PATH
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
執行source /etc/profile
使配置生效。
編寫Shell腳本自動化Java編譯流程,提升效率?;A示例如下:
#!/bin/bash
# 設置目錄與變量
SRC_DIR="src" # 源代碼目錄
OUTPUT_DIR="bin" # 編譯輸出目錄
PACKAGE_NAME="com.example" # 包名(若有)
# 創建輸出目錄
mkdir -p $OUTPUT_DIR
# 編譯Java文件(支持子目錄)
javac -d $OUTPUT_DIR -sourcepath $SRC_DIR $(find $SRC_DIR -name "*.java")
# 檢查編譯結果
if [ $? -eq 0 ]; then
echo "Compilation successful!"
# 運行程序(需替換MainClass為實際主類)
java -cp $OUTPUT_DIR $PACKAGE_NAME.MainClass
else
echo "Compilation failed!"
fi
優化技巧:
javac -Xincgc
減少重復編譯時間;javac -J-XX:ParallelGCThreads=4
利用多核處理器加速;mvn clean install
)或Gradle管理依賴與編譯,避免手動處理。編寫Shell腳本管理Java應用的啟動、停止與狀態檢查,示例如下(myapp.sh
):
#!/bin/bash
APP_NAME="MyJavaApp"
JAVA_HOME="/usr/lib/jvm/java-1.8.0-openjdk"
JAR_FILE="myapp.jar" # 應用JAR路徑
JAVA_OPTS="-Xms512m -Xmx1024m" # JVM內存設置
PID_FILE="$APP_NAME.pid" # 進程ID文件
# 啟動應用
start() {
if [ -f $PID_FILE ]; then
echo "Application is already running (PID: $(cat $PID_FILE))."
exit 1
fi
echo "Starting $APP_NAME..."
nohup $JAVA_HOME/bin/java $JAVA_OPTS -jar $JAR_FILE > /dev/null 2>&1 &
echo $! > $PID_FILE
echo "$APP_NAME started with PID $(cat $PID_FILE)."
}
# 停止應用
stop() {
if [ ! -f $PID_FILE ]; then
echo "Application is not running."
exit 1
fi
echo "Stopping $APP_NAME..."
kill $(cat $PID_FILE) && rm -f $PID_FILE
echo "$APP_NAME stopped."
}
# 檢查狀態
status() {
if [ -f $PID_FILE ]; then
echo "$APP_NAME is running with PID $(cat $PID_FILE)."
else
echo "$APP_NAME is not running."
fi
}
# 根據參數執行對應操作
case "$1" in
start) start ;;
stop) stop ;;
status) status ;;
*) echo "Usage: $0 {start|stop|status}"; exit 1 ;;
esac
使用說明:賦予執行權限(chmod +x myapp.sh
),通過./myapp.sh start
啟動、./myapp.sh stop
停止、./myapp.sh status
查看狀態。
使用日志框架(如SLF4J+Logback)替代System.out.println
,實現日志分級(DEBUG/INFO/WARN/ERROR)與文件輸出。示例logback.xml
配置:
<configuration>
<appender name="FILE" class="ch.qos.logback.core.FileAppender">
<file>logs/app.log</file>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<root level="INFO">
<appender-ref ref="FILE" />
</root>
</configuration>
在代碼中通過LoggerFactory.getLogger(Class.class)
獲取Logger實例,記錄日志:
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class MyClass {
private static final Logger logger = LoggerFactory.getLogger(MyClass.class);
public void doSomething() {
logger.info("Starting process...");
try {
// 業務邏輯
logger.debug("Debug information");
} catch (Exception e) {
logger.error("Error occurred: ", e);
}
}
}
注意:確保日志目錄(如logs
)存在且有寫入權限。
通過JVM參數開啟遠程調試,配合IDE(如IntelliJ IDEA)定位問題。修改啟動腳本(如myapp.sh
),添加以下參數:
JAVA_OPTS="$JAVA_OPTS -agentlib:jdwp=transport=dt_socket,address=8000,server=y,suspend=n"
步驟:
-Xms
初始堆、-Xmx
最大堆)、選擇垃圾回收器(如G1GC:-XX:+UseG1GC
);使用JUnit框架編寫單元測試,覆蓋核心邏輯。示例測試類:
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class CalculatorTest {
@Test
public void testAdd() {
Calculator calc = new Calculator();
assertEquals(5, calc.add(2, 3));
}
}
通過Maven運行測試(mvn test
),確保代碼變更后功能正常。