docker部署文档(一)

其中oracleredis在第一次部署完成后再也不须要大的变更, 工程容器则须要常常升级, nginx容器也须要常常重启.css

注意点:前端

  1. docker run-v选项是将宿主机目录挂载到容器中的指定目录, 这是一个覆盖的操做.nginx

  2. 挂载的日志目录务必放在宿主机的空间较大的分区上, 以避免日志满而形成服务没法运行. 该文档中认为/opt是空间较大的分区.redis

  3. docker服务会接管宿主机的防火墙, 容器与宿主机的端口映射都是有docker经过iptables完成的, 因此不要再执行关闭或清空防火墙的操做.sql

1. oracle容器操做

启动容器

$ docker run -d --privileged  --restart=always \--shm-size 2147483648 \-p 1521:1521 \-v /opt/oracle:/opt/oracle \reg01.sky-mobi.com/huoshu/oracle-final:1.0.3

使用docker-enter进入容器, 执行初始化脚本, 并启动数据实例docker

## 执行初始化脚本, 使sysctl配置生效bash /root/init.sh 
## 切换用户su - oracle## 启动oracle监听器lsnrctl  start## 进入sqlplus命令行sqlplus "/as sysdba"SQL> startup
ORACLE instance started.

Total System Global Area 3206836224 bytes
Fixed Size          2217632 bytes
Variable Size         369101152 bytes
Database Buffers     2818572288 bytes
Redo Buffers           16945152 bytes
Database mounted.
Database opened.
SQL>

退出容器, 回到宿主机命令行.apache

若是oracle容器在独立的服务器上, 则不须要指定IP, 只须要映射容器的1521端口到宿主机自己的1521端口上便可.tomcat

注意:bash

因为--restart=always启动参数的存在, 容器异常崩溃时会自动重启. 其余容器都设置了启动时自动运行其中的服务的规则, 可是oracle容器没有这个配置, 因此oracle容器挂掉后依然须要手动进入容器再执行一遍上述操做.服务器

数据存储目录须要单独打包. 启动时也应把这个目录挂载出来, 以防容器崩溃时数据丢失.

2. nginx容器操做

2.1 启动容器

docker run -d --restart=always \
--net huoshu --ip=172.21.0.2 -p 80:80 -p 81:81 \
-v /opt/apps/front:/opt/apps \
-v /opt/apps/front/nginx.conf.d:/etc/nginx/conf.d \
-v /var/log/nginx:/var/log/nginx \
reg01.sky-mobi.com/huoshu/nginx:1.0.0

关于升级

上述启动命令中挂载的/opt/apps/front的目标结构以下.

$ tree -L 2.
├── bi_FE
├── hdc_FE
└── nginx.conf.d
    ├── bi.conf
    └── hdc.conf

其中nginx.conf.d挂载到nginx容器的/etc/nginx/conf.d目录, 因此能够直接在宿主机上编辑这个文件再重启容器中的nginx.

另外, 因为/opt/apps/front目录整个挂载到容器中, 在nginx容器运行期间, 这个目录不可删除. 升级前端工程时须要将新的工程包放到这个/opt/apps/front目录下, 替换掉原来的工程目录, 而后重启nginx.

不可删除的缘由, nginx容器持有/opt/apps/front目录的句柄, 删除这个目录只是删除了它的索引, 实际存储块还在. 新建的目录不会从新挂载到容器.

2.2 nginx重启命令

不用进入容器就能够执行命令, 使用docker exec 容器id 目标命令, 以下

$ docker exec c98790552123 nginx -tnginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful$ docker exec c98790552123 nginx -s reload

固然, docker-enter进入容器再操做也是同样的.

3. redis容器操做

启动命令: 映射端口, 挂载存储及日志目录(都在/var/log目录下).

$ docker run -d --restart=always \
--net huoshu --ip=172.21.0.3 -p 6379:6379 \
-v /var/log/redis:/var/log/redis \
reg01.sky-mobi.com/huoshu/redis:1.0.0

4. 工程容器

注意:

  1. --net--ip-p选项指定的值与nginx的配置文件对应, 不要轻易修改.

  2. ORACLE_ADDR变量, 不一样医院的oracle地址要在启动时指定, 根据实际状况修改.

etlloader

$ docker run -d --restart=always --name etlloader \--net huoshu --ip 172.21.1.4 -p 8380:8080 \-e ORACLE_ADDR=172.16.4.101 \-v /var/log/etlloader:/opt/etlloader/consolelog \reg01.sky-mobi.com/huoshu/etlloader:1.0.0

skydata-se

$ docker run -d --restart=always --name skydata-se \--net huoshu --ip=172.21.1.3 -p 8280:8080 \-v /var/log/skydata-se:/usr/local/apache-tomcat-8.5.4/logs \-e ORACLE_ADDR=172.16.4.101 \reg01.sky-mobi.com/huoshu/skydata-se:1.0.0

hdc-manager

$ docker run -d --restart=always --name hdc-manager \--net huoshu --ip=172.21.1.2 -p 8180:8080 \-v /var/log/hdc-manager:/usr/local/apache-tomcat-8.5.4/logs \-e ORACLE_ADDR=172.16.4.101 \reg01.sky-mobi.com/huoshu/hdc-manager:1.0.0

drgs

$ docker run -d --restart=always \--net huoshu --ip 172.21.1.5 -p 9998:9998 \-e ORACLE_ADDR=172.16.4.101 \-v /var/log/drgs:/opt/drgs/log \reg01.sky-mobi.com/huoshu/drgs:1.0.0
相关文章
相关标签/搜索