Docker线上应用实践

Docker 安装

#使用 root 权限登录 Centos。确保 yum 包更新到最新。
sudo yum update

#卸载旧版本(如果安装过旧版本的话)
sudo yum remove docker  docker-common docker-selinux docker-engine

#安装需要的软件包, yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的
sudo yum install -y yum-utils device-mapper-persistent-data lvm2

#设置Docker yum源
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

#可以查看所有仓库中所有docker版本,并选择特定版本安装
yum list docker-ce --showduplicates | sort -r

#安装docker
sudo yum install docker-ce || sudo yum install docker-ce-17.12.0.ce 

#启动并加入开机启动
sudo systemctl start docker
sudo systemctl enable docker
清理docker的空间
docker container prune
docker image prune -a

DockerHub 加速

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
    "registry-mirrors": [
        "https://1nj0zren.mirror.aliyuncs.com",
        "https://docker.mirrors.ustc.edu.cn",
        "http://f1361db2.m.daocloud.io",
        "https://registry.docker-cn.com"
    ]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

Docker 基本命令

# 前台运行
docker run -it image:version
# 后台运行
docker run -d image:version
# 进入容器内部
docker exec -it container /bin/bash

# 创建网络
docker network create network
# 使用创建的网络启动容器
docker run --network congnet image

# 杀死所有正在运行的容器
docker kill $(docker ps -a -q)
# 删除所有已经停止的容器
docker rm $(docker ps -a -q)
# 删除所有未打 dangling 标签的镜
docker rmi $(docker images -q -f dangling=true)
# 删除所有镜像
docker rmi $(docker images -q)
# 强制删除所有镜像
docker rmi -f $(docker images -q)

DockerFile

FROM openjdk:11.0-jre

# 传入参数
ARG ACTIVE_PROFILE
ARG PROJECT_FIEL
ARG SHELL_FILE

# 作者信息
MAINTAINER The SpringBoot Project <931305033@qq.com>

# 添加业务服务jar包
ADD $PROJECT_FIEL /root/docker_test/app.jar
ADD $SHELL_FILE /root/docker_test/start.sh

# 开发对外端口
EXPOSE 8080
EXPOSE 7080

RUN chmod 777 /root/docker_test/start.sh
RUN /root/docker_test/start.sh "ADD_PARAMETER" "ACTIVE_PROFILE" $ACTIVE_PROFILE
RUN /bin/bash -c "source /root/.profile"
#
##docker 服务启动参数
ENTRYPOINT ["/root/docker_test/start.sh"]
CMD ["START", "ACTIVE_PROFILE"]

启动脚本

#!/bin/bash

# 日志文件路径 /root/catalina.out
# 配置文件路径 /root/config.properties
# Key:
#   ACTIVE_PROFILE - 项目环境

TYPE=$1
PARAMETER_KEY=$2
PARAMETER_VALUE=$3

JVM_LOG_PATH="/root/jvm"
CPU_COUNT=1

JAR_PATH="/root/docker_test/app.jar"
CATALINA_LOG=" > /root/catalina.out 2>&1 &"
SPRING_ACTIVE_PROFILE="--spring.profiles.active="

if [ "$TYPE" = 'ADD_PARAMETER' ];then
    # /root/.profile 取决于docker中profile所在的位置 通常在~/.bash_profile,确定后写成绝对地址
  echo "$PARAMETER_KEY"="$PARAMETER_VALUE" >> /root/config.properties

elif [ "$TYPE" = 'START' ];
  then
     . /root/config.properties
    SERVER_OPTS=''
    # 启动内存 运行最大内存
    SERVER_OPTS="$SERVER_OPTS -Xms256m -Xmx512m"
    # 年轻代大小为2G
    SERVER_OPTS="$SERVER_OPTS -Xmn256m"
    # 元空间初始化128 最大256
    SERVER_OPTS="$SERVER_OPTS -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=256m"
    # 堆外ByteBuffer 大小
    SERVER_OPTS="$SERVER_OPTS -XX:MaxDirectMemorySize=128m"
    # CMS GC 并行 FGC 提高FULL GC效率
    SERVER_OPTS="$SERVER_OPTS -XX:ExplicitGCInvokesConcurrent"
    # 并行GC的线程数
    SERVER_OPTS="$SERVER_OPTS -XX:ParallelGCThreads=${CPU_COUNT}"
    if [ "$PARAMETER_VALUE" = 'java9+' ]; then
      SERVER_OPTS="$SERVER_OPTS -Xlog:gc*:$JVM_LOG_PATH/gc.log:time"
    else
      SERVER_OPTS="$SERVER_OPTS -Xloggc:$JVM_LOG_PATH/gc.log -XX:+PrintGCDetails -XX PrintGCDetailsTamps"
    fi
    if [ "$PARAMETER_VALUE" = 'java8' ];
      then
        SERVER_OPTS="-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=7080"
    elif [ "$PARAMETER_VALUE" = 'java9+' ];
      then
        SERVER_OPTS="-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=*:7080"
    fi

    java "$SERVER_OPTS" -jar "-Duser.timezone=GMT+08" "$JAR_PATH" "$SPRING_ACTIVE_PROFILE""$ACTIVE_PROFILE" "$CATALINA_LOG"
    tail -f /dev/null
fi


Docker compose

# 此处需要和你的docker-compose版本一致,例如你的docker-compose版本为1.7.8 那么这个版本就是2
version: "3" 

# 服务,主要用来整合容器,表明他们之前的关系
services:
  # 二级标签是 app,这个名字是用户自己自定义,它就是服务名称。
  app:
    # 基于一份 Dockerfile,在使用 up 启动之时执行构建任务,
    # 这个构建标签就是 build,它可以指定 Dockerfile 所在文件夹的路径
    # 这里就是找当前下的build-script文件夹
    build: build-script
    # 加入指定网络
    networks:
      - network
    # 容器的依赖、启动先后的问题,先启动依赖
    depends_on:
      - db
    ports:
      - 2368:2368
  db:
    #指定服务的镜像名称或镜像 ID
    image: mysql:5.7.20
    networks:
      - network
    #设置镜像变量,它可以保存变量到镜像里面
    environment:
      MYSQL_ROOT_PASSWORD: mysqlroot
      MYSQL_USER: ghost
      MYSQL_PASSWORD: ghost
    #挂载一个目录或者一个已存在的数据卷容器,
    volumes:
      - ./data:/var/lib/mysql
    ports:
      - 3306:3306
#查看帮助
docker-compose -h

# -f  指定使用的 Compose 模板文件,默认为 docker-compose.yml,可以多次指定。
docker-compose -f docker-compose.yml up -d 

#启动所有容器,-d 将会在后台启动并运行所有的容器
docker-compose up -d

#停用移除所有容器以及网络相关
docker-compose down

#查看服务容器的输出
docker-compose logs

#列出项目中目前的所有容器
docker-compose ps

#构建(重新构建)项目中的服务容器。服务容器一旦构建后,将会带上一个标记名,例如对于 web 项目中的一个 db 容器,可能是 web_db。可以随时在项目目录下运行 docker-compose build 来重新构建服务
docker-compose build

#拉取服务依赖的镜像
docker-compose pull

#重启项目中的服务
docker-compose restart

#删除所有(停止状态的)服务容器。推荐先执行 docker-compose stop 命令来停止容器。
docker-compose rm 

#在指定服务上执行一个命令。
docker-compose run ubuntu ping docker.com

#设置指定服务运行的容器个数。通过 service=num 的参数来设置数量
docker-compose scale web=3 db=2

#启动已经存在的服务容器。
docker-compose start

#停止已经处于运行状态的容器,但不删除它。通过 docker-compose start 可以再次启动这些容器。
docker-compose stop

Docker 常见问题

  • Docker 容器启动时,默认会把容器内部第一个进程,也就是pid=1的程序,作为docker容器是否正在运行的依据,如果 docker 容器pid=1的进程挂了,那么docker容器便会直接退出。
    Docker未执行自定义的CMD之前,nginx的pid是1,执行到CMD之后,nginx就在后台运行,bash或sh脚本的pid变成了1。
    所以一旦执行完自定义CMD,nginx容器也就退出了。

  • 网络问题,两容器互相ping不同,需要创建一个网络,两个容器链接到同一网络,即可ping通

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你向着阳光奔跑的背影

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值