zoukankan      html  css  js  c++  java
  • Linux : Docker安装Jenkins

    1. 安装jenkins: docker run   -u root   -d   -p 9999:8080   -p 50000:50000   -v jenkins-data:/var/jenkins_home   -v /var/run/docker.sock:/var/run/docker.sock   jenkinsci/blueocean

    2. 使用初始密码登陆, 初始密码位置: cat /var/jenkins_home/secrets/initialAdminPassword

    3. 直接选择推荐插件安装

    4. 安装插件:

      4.1. Ant Plugin  用来配置jdk+maven环境的插件

      4.2. LDAP Plugin  用来进行配置角色(用户组)权限的插件

      4.3 Localization: Chinese (Simplified)  中文语言插件 

      4.4 Publish Over SSH  把文件通过ssh发布到服务器的插件  (在系统配置的 Publish over SSH 中配置服务器信息 高级选项卡中配置服务器密码)

      4.5 Simple Theme Plugin  样式修改插件   (在系统配置的 Theme添加css url 如: http://192.168.1.231:9999/userContent/layout/my.css  和   http://192.168.1.231:9999/userContent/layout/title.css)

    5. 项目配置:

      5.1 java后端项目: (在docker里面安装java与maven, 并修改maven源) 

        选中丢弃旧的构建

        源码管理添加仓库与用户访问凭证

        指定分支 如 */dev

        添加构建步骤 执行 shell 如      mvn clean && mvn package -DskipTests

        添加步骤 send files or execute commands over ssh    (下图中 Exec command里面 run.sh 前 少了个 / )

        

       5.2 前端项目 (在docker里面安装node, 并修改npm源, 安装zip) 

        执行 shell命令: 

    npm install &&
    npm run build:prod &&
    cd dist &&
    zip dist.zip * -r

        

    附件:   unzip.sh脚本内容:

    #!/usr/bin/env bash
    source /etc/profile
    cd `dirname $0`
    rm -rf dist/
    unzip dist.zip -d dist

    run.sh脚本内容:

    #!/bin/bash
    source /etc/profile
    # Spring-Boot 常规启动脚本,基于HotSpot Java8
    # 使用方式:xx.sh [start|stop|restart|status|dump]
    # 将Spring-Boot Jar包和此脚本放在同一目录下,之后配置APP_NAME/PROFILE即可
    
    cd `dirname $0`
    # 应用名(boot jar包名)
    APP_NAME=demo
    
    # Spring-Boot环境名(profiles)
    PROFILE=
    
    JAR_NAME=$APP_NAME.jar
    PID=$APP_NAME.pid
    APP_HOME=`pwd`
    LOG_PATH=$APP_HOME/logs
    GC_LOG_PATH=$LOG_PATH/gc
    DEBUG_FLAG=$2
    app_path=$(cd `dirname $0`; pwd)
    app_log="${app_path}/app.log"
    
    if [ ! -d $LOG_PATH ]; then
        mkdir $LOG_PATH
    fi
    
    if [ ! -d $GC_LOG_PATH ]; then
        mkdir $GC_LOG_PATH
    fi
    
    # DUMP父目录
    DUMP_DIR=$LOG_PATH/dump
    if [ ! -d $DUMP_DIR ]; then
        mkdir $DUMP_DIR
    fi
    
    # DUMP目录前缀
    DUMP_DATE=`date +%Y%m%d%H%M%S`
    
    # DUMP目录
    DATE_DIR=$DUMP_DIR/$DUMP_DATE
    if [ ! -d $DATE_DIR ]; then
        mkdir $DATE_DIR
    fi
    
    
    # GC日志参数
    GC_LOG_OPTS="-XX:+PrintGCDetails -XX:+PrintGCDateStamps -Xloggc:$GC_LOG_PATH/gc-%t.log"
    
    # OOM Dump内存参数
    DUMP_OPTS="-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=$LOG_PATH"
    
    # JVM DEBUG参数,用于调试,默认不开启
    
    # ClassLoader和Method Compile日志,用于调试
    COMPILE_LOADER_OPTS="-XX:+TraceClassLoading -XX:+TraceClassUnloading -XX:-PrintCompilation"
    
    # 远程调试参数
    REMOTE_DEBUG_OPTS="-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=5005"
    
    # DEBUG参数
    DEBUG_OPTS="$COMPILE_LOADER_OPTS $REMOTE_DEBUG_OPTS"
    
    # 至于Garbage Collector,虽然Java8已经支持G1了,但是不一定必须用,CMS在默认场景下也是一个优秀的回收器
    GC_OPTS="-XX:+UseConcMarkSweepGC"
    
    OTHER_OPTS="-Djava.security.egd=file:/dev/./urandom"
    
    # JVM 启动参数,如无特殊需求,推荐只配置堆+元空间
    JVM_OPTIONS="-server -Xms2g -Xmx2g -XX:MetaspaceSize=256m $GC_OPTS $GC_LOG_OPTS $DUMP_OPTS $OTHER_OPTS"
    
    #使用说明,用来提示输入参数
    usage() {
        echo "Usage: sh [run_script].sh [start|stop|restart|status|dump]"
        exit 1
    }
    
    #检查程序是否在运行
    is_exist(){
      pid=`ps -ef|grep $APP_HOME/$JAR_NAME|grep -v grep|awk '{print $2}' `
      #如果不存在返回1,存在返回0     
      if [ -z "${pid}" ]; then
       return 1
      else
        return 0
      fi
    }
    
    #启动方法
    start(){
      is_exist
      if [ $? -eq "0" ]; then 
        echo "--- ${JAR_NAME} is already running PID=${pid} ---" 
      else 
          if [ "$DEBUG_FLAG" = "debug" ]; then
            JVM_OPTIONS="$JVM_OPTIONS $DEBUG_OPTS"
            echo -e "33[33m Warning: currently running in debug mode! This mode enables remote debugging, printing, compiling, and other information 33[0m"
        fi
          echo "JVM_OPTIONS : "
          echo "$JVM_OPTIONS"
        nohup java -jar $JVM_OPTIONS -Dspring.profiles.active=$PROFILE $APP_HOME/$JAR_NAME >${app_log} 2>&1 &
        echo $! > $PID
        echo "--- start $JAR_NAME successed PID=$! ---" 
        #tail -f ${app_log}
       fi
      }
    
    
    stop(){
      #is_exist
      pidf=$(cat $PID)
      #echo "$pidf"  
      echo "--- app PID = $pidf begin kill $pidf ---"
      kill $pidf
      rm -rf $PID
      sleep 2
      is_exist
      if [ $? -eq "0" ]; then 
        echo "--- app 2 PID = $pid begin kill -9 $pid  ---"
        kill -9  $pid
        sleep 2
        echo "--- $JAR_NAME process stopped ---"  
      else
        echo "--- ${JAR_NAME} is not running ---"
      fi  
    }
    
    
    status(){
      is_exist
      if [ $? -eq "0" ]; then
        echo "--- ${JAR_NAME} is running PID is ${pid} ---"
      else
        echo "--- ${JAR_NAME} is not running ---"
      fi
    }
    
    dump(){
      is_exist
      if [ $? -eq "0" ]; then 
        echo -e "Dumping the $JAR_NAME ...c"
        do_dump
      else 
        echo "--- ${JAR_NAME} is not running ---"
       fi
     }
    
    #重启
    restart(){
      stop
      start
    }
    
    do_dump(){
        jmap -dump:format=b,file=$DATE_DIR/jmap-dump-$pid.hprof $pid 2>&1
        echo -e ".c"
        jstack $pid > $DATE_DIR/jstack-$pid.dump 2>&1
        echo -e ".c"
        jinfo $pid > $DATE_DIR/jinfo-$pid.dump 2>&1
        echo -e ".c"
        jstat -gcutil $pid > $DATE_DIR/jstat-gcutil-$pid.dump 2>&1
        echo -e ".c"
        jstat -gccapacity $pid > $DATE_DIR/jstat-gccapacity-$pid.dump 2>&1
        echo -e ".c"
        jmap $pid > $DATE_DIR/jmap-$pid.dump 2>&1
        echo -e ".c"
        jmap -heap $pid > $DATE_DIR/jmap-heap-$pid.dump 2>&1
        echo -e ".c"
        jmap -histo $pid > $DATE_DIR/jmap-histo-$pid.dump 2>&1
        echo -e ".c"
        jmap -dump:format=b,file=jmap-dump-$pid.bin $pid
        echo -e ".c"
        if [ -r /usr/sbin/lsof ]; then
        /usr/sbin/lsof -p $pid > $DATE_DIR/lsof-$pid.dump
        echo -e ".c"
        fi
    
        if [ -r /bin/netstat ]; then
        /bin/netstat -an > $DATE_DIR/netstat.dump 2>&1
        echo -e ".c"
        fi
        if [ -r /usr/bin/iostat ]; then
        /usr/bin/iostat > $DATE_DIR/iostat.dump 2>&1
        echo -e ".c"
        fi
        if [ -r /usr/bin/mpstat ]; then
        /usr/bin/mpstat > $DATE_DIR/mpstat.dump 2>&1
        echo -e ".c"
        fi
        if [ -r /usr/bin/vmstat ]; then
        /usr/bin/vmstat > $DATE_DIR/vmstat.dump 2>&1
        echo -e ".c"
        fi
        if [ -r /usr/bin/free ]; then
        /usr/bin/free -t > $DATE_DIR/free.dump 2>&1
        echo -e ".c"
        fi
        if [ -r /usr/bin/sar ]; then
        /usr/bin/sar > $DATE_DIR/sar.dump 2>&1
        echo -e ".c"
        fi
        if [ -r /usr/bin/uptime ]; then
        /usr/bin/uptime > $DATE_DIR/uptime.dump 2>&1
        echo -e ".c"
        fi
    
        echo "OK!"
        echo "DUMP: $DATE_DIR"
    }
    
    case "$1" in
      "start")
        start
        ;;
      "stop")
        stop
        ;;
      "status")
        status
        ;;
      "restart")
        restart
        ;;
      "dump")
        dump
      ;;
      *)
        usage
        ;;
    esac
    exit 0
  • 相关阅读:
    PCL配置即常见问题
    opencv2.4.9配置+VS2013
    我的项目配置问题及解决
    Java 8 函数式编程
    leecode刷题(17)-- 实现StrStr
    leecode刷题(16)-- 字符串转换整数
    leecode刷题(15)-- 验证回文字符串
    博客迁移通知
    leecode刷题(14)-- 有效的字母异位词
    leecode刷题(13) -- 字符串中的第一个唯一字符
  • 原文地址:https://www.cnblogs.com/cccy0/p/13895853.html
Copyright © 2011-2022 走看看