docker实战部署Javaweb项目

一、部署环境说明

docker服务版本:
version 18.09.0
nginx服务版本:
version: nginx/1.15.10
redis服务版本:
version: redis/5.0.3
tomcat服务版本:
version: tomcat/8.5.30
JDK服务版本:
alpine-oraclejdk8

二、安装docker服务

配置阿里yum源并安装docker

# yum install docker -y

三、项目部署

1、准备工作

拉取如下镜像

# docker images

[root@localhost ~]# docker images
REPOSITORY                                             TAG                 IMAGE ID            CREATED             SIZE
nginx                                                  1.15.10             2bcb04bdb83f        3 months ago        109MB
tomcat                                                 8.5.30              38bdcf7a367c        14 months ago       546MB
redis                                                  latest              82629e941a38        6 months ago        95MB
huanwei/alpine-oraclejdk8                              latest              28e66d63b8a4        2 years ago         167MB

拉取命令如下:

# docker pull docker.io/huanwei/alpine-oraclejdk8

# docker pull daocloud.io/library/tomcat:8.5.30

# docker pull daocloud.io/library/nginx:1.15.10

# docker pull daocloud.io/library/redis:5.0.3

镜像重命名

# docker tag daocloud.io/library/nginx:1.15.10 nginx:1.15.10

# docker tag daocloud.io/library/tomcat:8.5.30 tomcat:8.5.30

删除旧的镜像名

# docker rmi daocloud.io/library/nginx:1.15.10

# docker rmi daocloud.io/library/tomcat:8.5.30

软件版本说明:
nginx version: nginx/1.15.10
redis version: redis/5.0.3
tomcat version: tomcat/8.5.30
alpine-oraclejdk8

2、创建两个tomcat容器

创建一个测试tomcat容器,用于拷贝tomcat原文件

# docker run --name test -d -i -t tomcat:8.5.30 /bin/bash

[root@localhost docker-server]# docker run --name test -d -i -t tomcat:8.5.30 /bin/bash
1287b583d3b7b85a65ea4d80640124fc5dbd1905d0fc5c33ef05e0ba9872c681

进入测试容器熟悉tomcat安装位置

# docker exec -it test bash

[root@localhost docker-server]# docker exec -it test bash
root@1287b583d3b7:/usr/local/tomcat#
root@1287b583d3b7:/usr/local/tomcat# ls
LICENSE  NOTICE  RELEASE-NOTES  RUNNING.txt  bin  conf  include  lib  logs  native-jni-lib  temp  webapps  work
root@1287b583d3b7:/usr/local/tomcat#
root@1287b583d3b7:/usr/local/tomcat# pwd
/usr/local/tomcat
root@1287b583d3b7:/usr/local/tomcat#
root@1287b583d3b7:/usr/local/tomcat# cd ..
root@1287b583d3b7:/usr/local#
root@1287b583d3b7:/usr/local# ls
bin  etc  games  include  lib  man  sbin  share  src  tomcat
root@1287b583d3b7:/usr/local#
root@1287b583d3b7:/usr/local# exit
exit

拷贝容器的tomcat文件用于后期的tomcat映射挂载

# docker cp test:/usr/local/tomcat /home/tjsp/

[root@localhost docker-server]# docker cp test:/usr/local/tomcat /home/tjsp/
[root@localhost docker-server]# cd ..
[root@localhost tjsp]# ls
docker-server  tomcat
[root@localhost tjsp]#
[root@localhost tjsp]# cd tomcat/
[root@localhost tomcat]#
[root@localhost tomcat]#
[root@localhost tomcat]# ls
LICENSE  NOTICE  RELEASE-NOTES  RUNNING.txt  bin  conf  include  lib  logs  native-jni-lib  temp  webapps  work
[root@localhost tomcat]#

复制tomcat文件用于映射挂载tomcat1服务

[root@localhost tjsp]# cp -r tomcat/ tomcat1
[root@localhost tjsp]#
[root@localhost tjsp]#
[root@localhost tjsp]# ls
docker-server  tomcat  tomcat1
[root@localhost tjsp]#

创建容器

# docker run -p 8081:8080 --name tomcat1 -h Front-end1 -v /home/tjsp/tomcat1:/usr/local/tomcat -d tomcat:8.5.30

# docker run -p 8082:8080 --name tomcat2 -h Front-end2 -v /home/tjsp/tomcat2:/usr/local/tomcat -d tomcat:8.5.30

[root@localhost tjsp]# docker run -p 8081:8080 --name tomcat1 -h Front-end1 -v /home/tjsp/tomcat1:/usr/local/tomcat -d tomcat:8.5.30
d41f7b69ebbf9717629b220907fc7c88e8d106f2b99a805c6b0465b4bc49f484
[root@localhost tjsp]#
[root@localhost tjsp]# docker run -p 8082:8080 --name tomcat2 -h Front-end2 -v /home/tjsp/tomcat2:/usr/local/tomcat -d tomcat:8.5.30
78b5482a0a9546f5355fccb8f28bf4e08751f58e74b8a3b66af36a775ae31788
[root@localhost tjsp]#

 查看运行状态

# docker ps

[root@localhost ~]# docker ps
CONTAINER ID        IMAGE                                                  COMMAND                  CREATED             STATUS              PORTS                    NAMES
78b5482a0a95        tomcat:8.5.30                                          "catalina.sh run"        About an hour ago   Up About an hour    0.0.0.0:8082->8080/tcp   tomcat2
d41f7b69ebbf        tomcat:8.5.30                                          "catalina.sh run"        About an hour ago   Up About an hour    0.0.0.0:8081->8080/tcp   tomcat1
1287b583d3b7        tomcat:8.5.30                                          "/bin/bash"              About an hour ago   Up About an hour    8080/tcp                 test

添加office服务,运行一个tomcat跑war包

# cp -r tomcat tomcat3

[root@localhost ~]# cd /home/tjsp/
[root@localhost tjsp]#
[root@localhost tjsp]# ls
docker-server  nginx  tomcat  tomcat1  tomcat2
[root@localhost tjsp]#
[root@localhost tjsp]# cp -r tomcat tomcat3
[root@localhost tjsp]#
[root@localhost tjsp]# ls
docker-server  nginx  tomcat  tomcat1  tomcat2  tomcat3

创建一个tomcat容器

# docker run -p 8086:8080 --name tomcat3 -h tjsp_office -v /home/tjsp/tomcat3:/usr/local/tomcat -d tomcat:8.5.30

[root@localhost tjsp]# docker run -p 8086:8080 --name tomcat3 -h tjsp_office -v /home/tjsp/tomcat3:/usr/local/tomcat -d tomcat:8.5.30
9fe494bf43bc446f9f021d19e25ec5e030e6031c8fc65dcc8f08609f3b4bc946
[root@localhost tjsp]#
[root@localhost tjsp]# docker ps
CONTAINER ID        IMAGE                                                  COMMAND                  CREATED             STATUS              PORTS                    NAMES
9fe494bf43bc        tomcat:8.5.30                                          "catalina.sh run"        6 seconds ago       Up 5 seconds        0.0.0.0:8086->8080/tcp   tomcat3

3、创建nginx容器

创建一个测试nginx容器,用于拷贝nginx原文件

# docker run --name nginx_test -h nignx1.15.10 -d nginx:1.15.10

# docker cp nginx_test:/etc/nginx /home/tjsp/

[root@localhost tjsp]# docker run --name nginx_test -h nignx1.15.10 -d nginx:1.15.10
0b02f6f222ef38aa2f39fa7ac5d5a588b5df24bb6d7e28fba90aa55b0a4bf82e
[root@localhost tjsp]#
[root@localhost tjsp]# docker ps
CONTAINER ID        IMAGE                                                  COMMAND                  CREATED             STATUS              PORTS                    NAMES
0b02f6f222ef        nginx:1.15.10                                          "nginx -g 'daemon of…"   4 seconds ago       Up 3 seconds        80/tcp                   nginx_test
78b5482a0a95        tomcat:8.5.30                                          "catalina.sh run"        About an hour ago   Up About an hour    0.0.0.0:8082->8080/tcp   tomcat2
d41f7b69ebbf        tomcat:8.5.30                                          "catalina.sh run"        About an hour ago   Up About an hour    0.0.0.0:8081->8080/tcp   tomcat1
1287b583d3b7        tomcat:8.5.30                                          "/bin/bash"              About an hour ago   Up About an hour    8080/tcp                 test
[root@localhost tjsp]#
[root@localhost tjsp]# docker cp nginx_test:/etc/nginx /home/tjsp/
[root@localhost tjsp]#
[root@localhost tjsp]# ls
docker-server  nginx  tomcat  tomcat1  tomcat2
[root@localhost tjsp]#
[root@localhost tjsp]# cd nginx/
[root@localhost nginx]#
[root@localhost nginx]# ls
conf.d  fastcgi_params  koi-utf  koi-win  mime.types  modules  nginx.conf  scgi_params  uwsgi_params  win-utf
[root@localhost nginx]#

创建容器

# docker run --name nginx_tjsp -h nignx1.15.10 -p 7080:80 -v /home/tjsp/nginx:/etc/nginx/ -d nginx:1.15.10

[root@localhost nginx]# docker run --name nginx_tjsp -h nignx1.15.10 -p 7080:80 -v /home/tjsp/nginx:/etc/nginx/ -d nginx:1.15.10
39e65baa524a62e2a07ad0ccc035baf829f3f9736148529b79d18452011bf390
[root@localhost nginx]#
[root@localhost nginx]# docker ps
CONTAINER ID        IMAGE                                                  COMMAND                  CREATED             STATUS              PORTS                    NAMES
39e65baa524a        nginx:1.15.10                                          "nginx -g 'daemon of…"   4 seconds ago       Up 3 seconds        0.0.0.0:7080->80/tcp     nginx_tjsp
0b02f6f222ef        nginx:1.15.10                                          "nginx -g 'daemon of…"   3 minutes ago       Up 3 minutes        80/tcp                   nginx_test
78b5482a0a95        tomcat:8.5.30                                          "catalina.sh run"        About an hour ago   Up About an hour    0.0.0.0:8082->8080/tcp   tomcat2
d41f7b69ebbf        tomcat:8.5.30                                          "catalina.sh run"        About an hour ago   Up About an hour    0.0.0.0:8081->8080/tcp   tomcat1
1287b583d3b7        tomcat:8.5.30                                          "/bin/bash"              About an hour ago   Up About an hour    8080/tcp                 test

修改nginx配置文件

# vi /home/tjsp/nginx/nginx.conf

配置文件如下:

user  root;
worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
   
    ## Proxy
    upstream tjsp_client_proxy {
         server 192.168.2.207:8081 weight=1 max_fails=2 fail_timeout=30s;
         server 192.168.2.207:8082 weight=1 max_fails=2 fail_timeout=30s;
    }
    
    
    upstream tjsp_server_proxy {
         server 192.168.2.207:8083 weight=1 max_fails=2 fail_timeout=30s;
         server 192.168.2.207:8084 weight=1 max_fails=2 fail_timeout=30s;
         server 192.168.2.207:8087 weight=1 max_fails=2 fail_timeout=30s;
    }
    
    
    upstream etl_server_proxy {
         server 192.168.2.207:8085 weight=1 max_fails=2 fail_timeout=30s;
         #server 172.17.8.20:8086 weight=1 max_fails=2 fail_timeout=30s;
    }
    
    upstream exp_server_proxy {
         server 192.168.2.207:8086 weight=1 max_fails=2 fail_timeout=30s;
    }
    
    server {
        listen       80;
        server_name localhost;
        error_page   500 502 503 504  /50x.html;
    location / {
                root html;
                autoindex on;
                autoindex_exact_size off;
                autoindex_localtime on;
                index  index.html index.htm;
                 
                }
    location /tjsp {
            root html;
                autoindex on;
                autoindex_exact_size off;
                autoindex_localtime on;
            index  index.html index.htm;
            add_header Access-Control-Allow-Origin *;
            add_header Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept";
            add_header Access-Control-Allow-Methods "GET, POST, OPTIONS";
            proxy_pass  http://tjsp_client_proxy/tjsp;
            #try_files $uri $uri/ /main
            proxy_redirect off; 
            proxy_set_header Host  $http_host;
            proxy_set_header Cookie $http_cookie;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
            client_max_body_size  300m;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
        }
         location /a_ssets {
                root html;
                autoindex on;
                autoindex_exact_size off;
                autoindex_localtime on;
                index  index.html index.htm;
                add_header Access-Control-Allow-Origin *;
                add_header Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept";
                add_header Access-Control-Allow-Methods "GET, POST, OPTIONS";
                proxy_pass  http://tjsp_client_proxy/assets;
                        #try_files $uri $uri/ /main
                proxy_redirect off;
                proxy_set_header Host  $http_host;
                proxy_set_header Cookie $http_cookie;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header X-Forwarded-Proto $scheme;
                client_max_body_size  300m;
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection "upgrade";
            }
        location /zjb {
            root   html;
            index  index.html index.htm;
            add_header Access-Control-Allow-Origin *;
            add_header Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept";
            add_header Access-Control-Allow-Methods "GET, POST, OPTIONS";
            proxy_pass  http://tjsp_server_proxy/;
            proxy_redirect off;
            proxy_set_header Host  $http_host;
            proxy_set_header Cookie $http_cookie;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
            client_max_body_size  300m;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
         }
      
        location /etl {
            root   html;
            index  index.html index.htm;
            add_header Access-Control-Allow-Origin *;
            add_header Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept";
            add_header Access-Control-Allow-Methods "GET, POST, OPTIONS";
            proxy_pass  http://etl_server_proxy/;
            proxy_redirect off;
            proxy_set_header Host  $http_host;
            proxy_set_header Cookie $http_cookie;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
            client_max_body_size  300m;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
       }
          location /exp {
                        root   html;
                        index  index.html index.htm;
                        add_header Access-Control-Allow-Origin *;
                        add_header Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept";
                        add_header Access-Control-Allow-Methods "GET, POST, OPTIONS";
                        proxy_pass  http://exp_server_proxy/office;
                        proxy_redirect off;
                        proxy_set_header Host  $http_host;
                        proxy_set_header Cookie $http_cookie;
                        proxy_set_header X-Real-IP $remote_addr;
                        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                        proxy_set_header X-Forwarded-Proto $scheme;
                        client_max_body_size  300m;
                        proxy_set_header Upgrade $http_upgrade;
                        proxy_set_header Connection "upgrade";
           }
           location /exl {
                        root   html;
                        index  index.html index.htm;
                        add_header Access-Control-Allow-Origin *;
                        add_header Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept";
                        add_header Access-Control-Allow-Methods "GET, POST, OPTIONS";
                        proxy_pass  http://etl_server_proxy/;
                        proxy_redirect off;
                        proxy_set_header Host  $http_host;
                        proxy_set_header Cookie $http_cookie;
                        proxy_set_header X-Real-IP $remote_addr;
                        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                        proxy_set_header X-Forwarded-Proto $scheme;
                        client_max_body_size  300m;
                        proxy_set_header Upgrade $http_upgrade;
                        proxy_set_header Connection "upgrade";
           }

        

    }  
       
}  
View Code

4、创建redis容器

说明:

redis的密码为123456

保护模式已经关闭

集群模式未开启

# docker run --name redis -h redis_tjsp -p 6379:6379 -d redis redis-server --requirepass "123456" --appendonly yes --protected-mode no

进入redis查看

# docker exec -it redis bash

[root@localhost tjsp]# docker run --name redis -h redis_tjsp -p 6379:6379 -d redis redis-server --requirepass "123456" --appendonly yes --protected-mode no
7626b4b8f3c1b2f8161341209f159167876cdc3fee8b3b90c180770dc426f3bd
[root@localhost tjsp]#
[root@localhost tjsp]# docker exec -it redis bash
root@redis_tjsp:/data#
root@redis_tjsp:/data# ls
appendonly.aof
root@redis_tjsp:/data#
root@redis_tjsp:/data# exit
exit
[root@localhost tjsp]#

 5、构建jdk镜像

创建一个构建目录
# mkdir -p /home/tjsp/docker-server
编写Dockerfile文件
# cd /home/tjsp/docker-server/
# vi Dockerfile
FROM docker.io/huanwei/alpine-oraclejdk8
ADD app.jar /
EXPOSE 8082
ENTRYPOINT ["java","-D java.security.egd=file:/dev./urandom","-jar","/app.jar","--spring.profiles.active=dev207"]
VOLUME /tmp

构建镜像

# docker build -t cnbi-tjsp:latest .

[root@localhost tjsp]# cd docker-server/
[root@localhost docker-server]#
[root@localhost docker-server]# ls
Dockerfile  app.jar
[root@localhost docker-server]#
[root@localhost docker-server]# docker build -t cnbi-tjsp:latest .
Sending build context to Docker daemon    113MB
Step 1/5 : FROM docker.io/huanwei/alpine-oraclejdk8
 ---> 28e66d63b8a4
Step 2/5 : ADD /app.jar //
 ---> 063e68f2e01a
Step 3/5 : EXPOSE 8082
 ---> Running in 9ab4a3c0fc63
Removing intermediate container 9ab4a3c0fc63
 ---> 7522d6d8ea7f
Step 4/5 : ENTRYPOINT ["java","-D java.security.egd=file:/dev./urandom","-jar","/app.jar"]
 ---> Running in 3726768330c0
Removing intermediate container 3726768330c0
 ---> d6ddeff92429
Step 5/5 : VOLUME /tmp
 ---> Running in b7ac287ab1c9
Removing intermediate container b7ac287ab1c9
 ---> 692144a74536
Successfully built 692144a74536
Successfully tagged cnbi-tjsp:latest
[root@localhost docker-server]#

查看构建的镜像

# docker images

[root@localhost docker-server]# docker images
REPOSITORY                                             TAG                 IMAGE ID            CREATED             SIZE
cnbi-tjsp                                              latest              692144a74536        3 minutes ago       280MB

6、创建djk镜像容器

创建挂载目录

# mkdir -p /home/tjsp/nginx/html/file

[root@localhost tjsp]# cd nginx/
[root@localhost nginx]# pwd
/home/tjsp/nginx
[root@localhost nginx]# ls
conf.d  fastcgi_params  koi-utf  koi-win  mime.types  modules  nginx.conf  scgi_params  uwsgi_params  win-utf
[root@localhost nginx]#
[root@localhost nginx]# mkdir -p html/file
[root@localhost nginx]#
[root@localhost nginx]# ls
conf.d  fastcgi_params  html  koi-utf  koi-win  mime.types  modules  nginx.conf  scgi_params  uwsgi_params  win-utf
[root@localhost nginx]#
[root@localhost nginx]# ls html/
file
[root@localhost nginx]#

创建容器

# docker run -itd -p 8083:8082 -v /home/tjsp/nginx/html/file/:/home/upload/ --name tjsp1 cnbi-tjsp

# docker run -itd -p 8084:8082 -v /home/tjsp/nginx/html/file/:/home/upload/ --name tjsp2 cnbi-tjsp

解决高并发时添加

# docker run -itd -p 8087:8082 -v /home/tjsp/nginx/html/file/:/home/upload/ --name tjsp3 cnbi-tjsp

查看启动情况

注意:启动前需要运行redis,nginx配置,tomcat前端

# docker ps

[root@localhost nginx]# docker run -itd -p 8083:8082 -v /home/tjsp/nginx/html/file/:/home/upload/ --name tjsp1 cnbi-tjsp
ea2df7c4d1051978e67f04ea0d79b7e14081a60bf9c0adfd24b2884bdcefa213
[root@localhost nginx]#
[root@localhost nginx]# docker run -itd -p 8084:8082 -v /home/tjsp/nginx/html/file/:/home/upload/ --name tjsp2 cnbi-tjsp
f0ed2dd79b9fc4797e84c8f8523660cd38b88fdd5b4ebd971b02eeaa18ce8d1e
[root@localhost nginx]#
[root@localhost nginx]# docker ps
CONTAINER ID        IMAGE                                                  COMMAND                  CREATED             STATUS                      PORTS                    NAMES
f0ed2dd79b9f        cnbi-tjsp                                              "java '-D java.secur…"   16 minutes ago      Up 5 seconds                0.0.0.0:8084->8082/tcp   tjsp2
ea2df7c4d105        cnbi-tjsp                                              "java '-D java.secur…"   17 minutes ago      Up 8 seconds                0.0.0.0:8083->8082/tcp   tjsp1
7626b4b8f3c1        redis                                                  "docker-entrypoint.s…"   About an hour ago   Up About an hour            0.0.0.0:6379->6379/tcp   redis
39e65baa524a        nginx:1.15.10                                          "nginx -g 'daemon of…"   About an hour ago   Up About a minute           0.0.0.0:7080->80/tcp     nginx_tjsp
78b5482a0a95        tomcat:8.5.30                                          "catalina.sh run"        2 hours ago         Up About a minute           0.0.0.0:8082->8080/tcp   tomcat2
d41f7b69ebbf        tomcat:8.5.30                                          "catalina.sh run"        2 hours ago         Up About a minute           0.0.0.0:8081->8080/tcp   tomcat1

 7、构建etl镜像

创建一个构建目录
# mkdir -p /home/tjsp/docker-etl
编写Dockerfile文件
# cd /home/tjsp/docker-etl/
# vi Dockerfile
FROM docker.io/huanwei/alpine-oraclejdk8
ADD app.jar /
ADD kettle5.4 /kettle5.4/
EXPOSE 8085
ENTRYPOINT ["java","-D java.security.egd=file:/dev./urandom","-jar","/app.jar"]
VOLUME /tmp

 # ls /home/tjsp/docker-etl/

[root@localhost docker-etl]# ls
Dockerfile  app.jar  kettle5.4  kettle5.4.zip

构建镜像

# docker build -t tjsp-etl:latest .

查看构建的镜像

# docker images

[root@localhost ~]# docker images
REPOSITORY                                             TAG                 IMAGE ID            CREATED             SIZE
tjsp-etl                                               latest              74c531083372        22 hours ago        970MB

8、创建etl镜像容器

创建容器

# docker run -itd --name tjsp-etl -p 8085:8085 tjsp-etl --network host

[root@localhost ~]# docker run -itd --name tjsp-etl -p 8085:8085 tjsp-etl --network host
e14d155e53192bd1027ee2ed4c0b8b145e41a964d6de824b91c23df3997a6548
[root@localhost ~]#
[root@localhost ~]# docker ps
CONTAINER ID        IMAGE                                                  COMMAND                  CREATED             STATUS              PORTS                    NAMES
e14d155e5319        tjsp-etl                                               "java '-D java.secur…"   11 seconds ago      Up 10 seconds       0.0.0.0:8085->8085/tcp   tjsp-etl
b4ded4008023        cnbi-tjsp                                              "java '-D java.secur…"   21 hours ago        Up 44 minutes       0.0.0.0:8087->8082/tcp   tjsp3
504c7fd1eec6        cnbi-tjsp                                              "java '-D java.secur…"   21 hours ago        Up 44 minutes       0.0.0.0:8084->8082/tcp   tjsp2
6b3c6ddee4c6        cnbi-tjsp                                              "java '-D java.secur…"   21 hours ago        Up 44 minutes       0.0.0.0:8083->8082/tcp   tjsp1
9fe494bf43bc        tomcat:8.5.30                                          "catalina.sh run"        25 hours ago        Up About an hour    0.0.0.0:8086->8080/tcp   tomcat3
7626b4b8f3c1        redis                                                  "docker-entrypoint.s…"   26 hours ago        Up 26 hours         0.0.0.0:6379->6379/tcp   redis
39e65baa524a        nginx:1.15.10                                          "nginx -g 'daemon of…"   26 hours ago        Up 25 hours         0.0.0.0:7080->80/tcp     nginx_tjsp
78b5482a0a95        tomcat:8.5.30                                          "catalina.sh run"        27 hours ago        Up 25 hours         0.0.0.0:8082->8080/tcp   tomcat2
d41f7b69ebbf        tomcat:8.5.30                                          "catalina.sh run"        27 hours ago        Up 25 hours         0.0.0.0:8081->8080/tcp   tomcat1

9、进入etl镜像容器设置kettle并启动

进入etl容器

# docker exec -it tjsp-etl /bin/sh

[root@localhost ~]# docker exec -it tjsp-etl /bin/sh
/ #
/ # ls
app.jar    bin        dev        etc        home       kettle5.4  lib        lib64      linuxrc    logs       media      mnt        proc       root       run        sbin       srv        sys        tmp        usr        var
/ #

设置kettle

/ # cd /root/
~ # ls -a
.                  ..                 .ash_history       .kettle            .oracle_jre_usage
~ #
~ # cd .kettle/
~/.kettle #
~/.kettle # ls
kettle.properties
~/.kettle #
# This file was generated by Pentaho Data Integration version 4.4.0.
#
# Here are a few examples of variables to set:
#
# PRODUCTION_SERVER = hercules
# TEST_SERVER = zeus
# DEVELOPMENT_SERVER = thor
#
# Note: lines like these with a # in front of it are comments
#
KETTLE_DEST_HOST=192.168.2.201
KETTLE_DEST_DATABASE=ORCL
KETTLE_DEST_PORT=1521
KETTLE_DEST_USER=BRDB_TJSP_1203
KETTLE_DEST_PASSWORD=cnbi2018

KETTLE_EAS_HOST=192.168.2.206
KETTLE_EAS_DATABASE=orcl
KETTLE_EAS_PORT=1521
KETTLE_EAS_USER=TJEAS
KETTLE_EAS_PASSWORD=123456
~/.kettle # pwd
/root/.kettle
~/.kettle #

添加kettle流程

# docker cp eas_to_brdb/ tjsp-etl:/root/

[root@localhost tjsp]# ll
total 16
drwxr-xr-x.  3 root root    77 Jul 23 16:00 docker-etl
drwxr-xr-x.  2 root root    39 Jul 23 15:46 docker-server
drwxr-xr-x.  4 root root    83 Jul 23 17:10 eas_to_brdb
drwxr-xr-x.  2 root root     6 Jul 24 09:38 etl_jar
drwxr-xr-x.  2 root root 12288 Jul 23 17:21 lib
drwxr-xr-x.  4 root root   211 Jul 23 18:40 nginx
drwxr-xr-x.  2 root root    21 Jul 24 11:45 tjsp_jar
drwxr-sr-x. 11 root root   197 May  5  2018 tomcat
drwxr-xr-x. 11 root root   197 Jul 23 09:11 tomcat1
drwxr-xr-x. 11 root root   197 Jul 23 09:20 tomcat2
drwxr-xr-x. 11 root root   197 Jul 23 11:46 tomcat3
[root@localhost tjsp]#
[root@localhost tjsp]# docker cp eas_to_brdb/ tjsp-etl:/root/
[root@localhost tjsp]#

启动kettle

/ # chmod -R 777 kettle5.4/
/ #
/ # chmod -R 777 /root/eas_to_brdb/
/ # cd kettle5.4/
/kettle5.4 #
/kettle5.4 # ls -l
total 7632
-rwxrwxrwx    1 root     root           551 Jun 14  2015 Carte.bat
drwxrwxrwx    1 root     root            35 Jul 23 06:09 Data Integration.app
-rwxrwxrwx    1 root     root           138 Jun 14  2015 Encr.bat
-rwxrwxrwx    1 root     root           131 Jun 14  2015 Import.bat
-rwxrwxrwx    1 root     root           136 Jun 14  2015 Kitchen.bat
-rwxrwxrwx    1 root     root         13366 Jun 14  2015 LICENSE.txt
-rwxrwxrwx    1 root     root           124 Jun 14  2015 Pan.bat
-rwxrwxrwx    1 root     root       7302319 Jun 14  2015 PentahoDataIntegration_OSS_Licenses.html
-rwxrwxrwx    1 root     root           537 Jun 14  2015 README_INFOBRIGHT.txt
-rwxrwxrwx    1 root     root           537 Jun 14  2015 README_LINUX.txt
-rwxrwxrwx    1 root     root           345 Jun 14  2015 README_OSX.txt
-rwxrwxrwx    1 root     root           341 Jun 14  2015 README_UNIX_AS400.txt
-rwxrwxrwx    1 root     root          3803 Jun 14  2015 Spoon.bat
-rwxrwxrwx    1 root     root            98 Jun 14  2015 SpoonConsole.bat
-rwxrwxrwx    1 root     root          1271 Jun 14  2015 SpoonDebug.bat
-rwxrwxrwx    1 root     root           405 Jun 14  2015 carte.sh
drwxrwxrwx    1 root     root            39 Jul 23 06:09 docs
-rwxrwxrwx    1 root     root           140 Jun 14  2015 encr.sh
-rwxrwxrwx    1 root     root          2354 Jun 14  2015 import-rules.xml
-rwxrwxrwx    1 root     root           275 Jun 14  2015 import.sh
-rwxrwxrwx    1 755      root           308 Jun 14  2015 kitchen.sh
drwxrwxrwx    1 root     root           107 Jul 23 06:09 launcher
drwxrwxrwx    2 root     root         12288 Jul 23 09:21 lib
drwxrwxrwx    1 root     root            58 Jul 23 06:09 libswt
-rwxrwxrwx    1 root     root           274 Jun 14  2015 pan.sh
drwxrwxrwx    1 root     root          4096 Jul 23 06:09 plugins
drwxrwxrwx    1 root     root           176 Jul 23 06:09 pwd
-rwxrwxrwx    1 root     root           522 Jun 14  2015 runSamples.bat
-rwxrwxrwx    1 root     root           305 Jun 14  2015 runSamples.sh
drwxrwxrwx    1 root     root            51 Jul 23 06:09 samples
-rwxrwxrwx    1 root     root          4098 Jun 14  2015 set-pentaho-env.bat
-rwxrwxrwx    1 root     root          3710 Jun 14  2015 set-pentaho-env.sh
drwxrwxrwx    1 root     root            29 Jul 23 06:09 simple-jndi
-rwxrwxrwx    1 root     root            31 Jun 14  2015 spoon.command
-rwxrwxrwx    1 root     root        353118 Jun 14  2015 spoon.ico
-rwxrwxrwx    1 root     root          2460 Jun 14  2015 spoon.png
-rwxrwxrwx    1 root     root          5341 Jun 14  2015 spoon.sh
drwxrwxrwx    1 root     root          4096 Jul 23 06:09 ui
-rwxrwxrwx    1 root     root          1628 Jun 14  2015 yarn.sh
/kettle5.4 #
/kettle5.4 # ls -l /root/
total 0
drwxrwxrwx    4 root     root            83 Jul 23 09:10 eas_to_brdb
/kettle5.4 #
/kettle5.4 # ./kitchen.sh -file /root/eas_to_brdb/eas_to_brdb.kjb
Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=256m; support was removed in 8.0
2019/07/24 05:55:09 - Kitchen - Start of run.
2019/07/24 05:55:14 - eas_to_brdb - Start of job execution
2019/07/24 05:55:14 - eas_to_brdb - Starting entry [load_dimension_data]
2019/07/24 05:55:14 - load_dimension_data - Starting entry [set_period_variable]
2019/07/24 05:55:14 - set_period_variable - Loading transformation from XML file [file:///root/eas_to_brdb/load_dimension_data/set_period_variable.ktr]
2019/07/24 05:55:14 - set_period_variable - Dispatching started for transformation [set_period_variable]
2019/07/24 05:55:14 - 获取传递期间.0 - Finished processing (I=0, O=0, R=1, W=1, U=0, E=0)
2019/07/24 05:55:15 - 设置期间变量.0 - Setting environment variables...
2019/07/24 05:55:15 - 起止期间计算.0 - Finished processing (I=0, O=0, R=1, W=1, U=0, E=0)
2019/07/24 05:55:15 - 设置期间变量.0 - Set variable ORGPERIOD to value [201808]
2019/07/24 05:55:15 - 设置期间变量.0 - Set variable ENDPERIOD to value [201808]
2019/07/24 05:55:15 - 设置期间变量.0 - Set variable ORGTIME to value [2018-08-01 00:00:00]
2019/07/24 05:55:15 - 设置期间变量.0 - Set variable ENDTIME to value [2018-08-32 00:00:00]
2019/07/24 05:55:15 - 设置期间变量.0 - Finished after 1 rows.
2019/07/24 05:55:15 - 设置期间变量.0 - Finished processing (I=0, O=0, R=1, W=1, U=0, E=0)
*****************************
*************************
********************
***************
**********
******

10、查看etl服务是否启动成功

监听端口

# lsof -i:8085

[root@localhost ~]# lsof -i:8085
COMMAND     PID USER   FD   TYPE   DEVICE SIZE/OFF NODE NAME
docker-pr 11347 root    4u  IPv6 20280487      0t0  TCP *:8085 (LISTEN)

查看容器启动后10行日志

# docker logs --tail 10 -tf tjsp-etl

[root@localhost ~]# docker logs --tail 10 -tf tjsp-etl
2019-07-24T04:30:02.092266671Z 2019-07-24 04:30:02.091  INFO 1 --- [isson-netty-1-2] o.r.c.pool.MasterPubSubConnectionPool    : 1 connections initialized for 192.168.2.207/192.168.2.207:6379
2019-07-24T04:30:02.101305132Z 2019-07-24 04:30:02.100 DEBUG 1 --- [           main] org.redisson.connection.DNSMonitor       : DNS monitoring enabled; Current masters: {redis://192.168.2.207:6379=192.168.2.207/192.168.2.207:6379}, slaves: {}
2019-07-24T04:30:02.727084940Z 2019-07-24 04:30:02.723 DEBUG 1 --- [           main] o.mybatis.spring.SqlSessionFactoryBean   : Scanned package: 'com.cnbi.cloud.etl.vo' for aliases
2019-07-24T04:30:02.816255252Z 2019-07-24 04:30:02.811  INFO 1 --- [           main] c.c.cloud.etl.config.FullSQLInterceptor  : mybatis intercept dialect:oracle
2019-07-24T04:30:02.816415640Z Logging initialized using 'class org.apache.ibatis.logging.stdout.StdOutImpl' adapter.
2019-07-24T04:30:02.820326603Z 2019-07-24 04:30:02.817 DEBUG 1 --- [           main] o.mybatis.spring.SqlSessionFactoryBean   : Parsed configuration file: 'class path resource [mybatis/mybatis.cfg.xml]'
2019-07-24T04:30:02.936385155Z 2019-07-24 04:30:02.933 DEBUG 1 --- [           main] o.mybatis.spring.SqlSessionFactoryBean   : Parsed mapper file: 'class path resource [mybatis/mapper/formulaMapper.xml]'
2019-07-24T04:30:02.948821805Z 2019-07-24 04:30:02.947 DEBUG 1 --- [           main] o.mybatis.spring.SqlSessionFactoryBean   : Parsed mapper file: 'class path resource [mybatis/mapper/synchronousDataMapper.xml]'
2019-07-24T04:30:02.980705201Z 2019-07-24 04:30:02.979 DEBUG 1 --- [           main] o.mybatis.spring.SqlSessionFactoryBean   : Parsed mapper file: 'class path resource [mybatis/mapper/TableCensusMapper.xml]'
2019-07-24T04:30:07.086914939Z 2019-07-24 04:30:07.086  INFO 1 --- [           main] com.cnbi.cloud.ETLApplication            : Started ETLApplication in 12.023 seconds (JVM running for 13.086)

end

猜你喜欢

转载自www.cnblogs.com/djlsunshine/p/11230246.html