docker环境安装
内网服务器环境为麒麟V4,属于arm64架构。服务器初始配置仅有JDK环境,其余环境都需要导入安装。
首先查看操作系统版本
#查看系统对应的linux os
cat /proc/version
输出的内容中有 “Ubuntu1~18.04.10” ,即银河麒麟与Ubuntu比较亲近,可以使用.deb安装包。
Ubuntu 各版本号和名称对照可查看
在docker官网中下载对应安装包
Index of linux/ubuntu/dists/xenial/pool/stable/arm64/
安装包共有3类,即 containerd.io、 docker-ce-cli、 docker-ce 三类安装包之间存在着依赖关系,所以需要顺序安装。
- 安装容器类服务,使用
dpkg -i containerd.io_XXXXXX.deb
指令进行安装。 - 安装docker客户端,cli 即为 client 的意思。使用
dpkg -i docker-ce-cli_XXXX.deb
指令进行安装。 - 安装docker服务端程序,使用
dpkg -i docker-ce_XXXX.deb
指令进行安装。
安装过程中若出现containerd.io 依赖于 libseccomp2 (>= 2.4.0)的问题,按照如下命令更新并安装。
apt-get update
apt-get install -y libltdl7 libseccomp2
启动docker并查看docker状态
#查看docker状态
service docker status
#或者
systemctl status docker
#启动docker
service docker start
#或者
systemctl start docker
docker镜像配置及导入、导出
根据生产环境服务器架构类型的不同拉取指定架构的docker容器
一、开启docker实验属性
在外部虚拟机的内部通过修改 docker 配置文件,并重载,可以在服务器上开启 docker 的实验属性。为配置文件 /etc/docker/daemon.json
添加 属性"experimental": true
。
若目录中无daemon.json文件,可按照下面内容新建文件。
{
"registry-mirrors": [
"https://dockerhub.azk8s.cn",
"https://docker.mirrors.ustc.edu.cn",
"http://hub-mirror.c.163.com"
],
"max-concurrent-downloads": 10,
"max-concurrent-uploads": 10,
"experimental": true,
"log-driver": "json-file",
"log-level": "warn",
"log-opts": {
"max-size": "10m",
"max-file": "3"
},
"data-root": "/var/lib/docker"
}
修改文件后,重启docker服务
systemctl daemon-reload
systemctl restart docker
二、拉取指定架构的镜像
在 docker pull 时指定参数,即可完成指定架构镜像的拉取。下面命令以拉取 arm64 架构的 nginx镜像为例。
docker pull --platform arm64 nginx
通过以下命令,可以确定镜像的架构信息
#可使用镜像名或容器ID
docker inspect nginx | grep Architecture
导出镜像至XXX.tar包
docker save -o XXX.tar nginx
将XXX.tar包导入至生产环境服务器的docker环境中
docker load < XXX.tar
查看容器内镜像信息
docker ps -a
Nginx容器启动并挂载目录
创建Nginx配置文件
启动前需要先创建Nginx外部挂载的配置文件( /home/nginx/conf/nginx.conf) 之所以要先创建 , 是因为Nginx本身容器只存在/etc/nginx 目录 , 本身就不创建 nginx.conf 文件 当服务器和容器都不存在 nginx.conf 文件时, 执行启动命令的时候 docker会将nginx.conf 作为目录创建 , 这并不是我们想要的结果 。
创建挂载目录
mkdir -p /home/nginx/conf
mkdir -p /home/nginx/log
mkdir -p /home/nginx/html
容器中的nginx.conf文件和conf.d文件夹复制到宿主机
# 生成容器
docker run --name nginx -p 80:80 -d nginx
# 将容器nginx.conf文件复制到宿主机
docker cp nginx:/etc/nginx/nginx.conf /home/nginx/conf/nginx.conf
# 将容器conf.d文件夹下内容复制到宿主机
docker cp nginx:/etc/nginx/conf.d /home/nginx/conf/conf.d
# 将容器中的html文件夹复制到宿主机
docker cp nginx:/usr/share/nginx/html /home/nginx/
创建Nginx容器并运行
# 直接执行docker rm nginx或者以容器id方式关闭容器
# 找到nginx对应的容器id
docker ps -a
# 关闭该容器
docker stop nginx
# 删除该容器
docker rm nginx
# 删除正在运行的nginx容器
docker rm -f nginx
docker run
-p 80:80
--name nginx
-v /home/nginx/conf/nginx.conf:/etc/nginx/nginx.conf
-v /home/nginx/conf/conf.d:/etc/nginx/conf.d
-v /home/nginx/log:/var/log/nginx
-v /home/nginx/html:/usr/share/nginx/html
-d nginx
命令 | 描述 |
–name nginx | 启动容器的名字 |
-d | 后台运行 |
-p 80:80 | 将容器的 80(后面) 端口映射到主机的 80(前面) 端口 |
-v /home/nginx/conf/nginx.conf:/etc/nginx/nginx.conf | 挂载nginx.conf配置文件 |
-v /home/nginx/conf/conf.d:/etc/nginx/conf.d | 挂载nginx配置文件 |
-v /home/nginx/log:/var/log/nginx | 挂载nginx日志文件 |
-v /home/nginx/html:/usr/share/nginx/html | 挂载nginx内容 |
#查看容器挂载目录和其相关信息,其中,Mount目录下为挂载信息,Source为外部文件路径,Destination为容器内指向路径
docker inspect nginx(镜像名或容器ID)
#查看docker容器(nginx)日志
docker logs -f nginx
#导出docker容器(nginx)日志
docker logs nginx > nginx.log
Redis容器配置并启动
创建以下内容
# 以/docker/redis为例
mkdir /docker/redis
mkdir /docker/redis/data
touch /docker/redis/redis.conf
touch /docker/redis/redis.bash
编辑Redis容器配置文件
vim /docker/redis/redis.conf
参考配置文件
# Redis配置文件
# Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程
daemonize no
# 指定Redis监听端口,默认端口为6379
port 6379
# 绑定的主机地址,不要绑定容器的本地127.0.0.1地址,因为这样就无法在容器外部访问
bind 0.0.0.0
# 持久化
appendonly yes
编辑容器启动脚本
vim /docker/redis/redis.bash
参考脚本
docker run -p 6379:6379 --name redis -v /docker/redis/redis.conf:/etc/redis/redis.conf -v /docker/redis/data:/data -d redis redis-server /etc/redis/redis.conf
docker run # 从redis镜像运行容器
-p 6379:6379 # 映射本地6379端口到容器6379端口,前为本地端口
--name redis # 设置容器名称为redis,方便以后使用docker ps进行管理
-v /docker/redis/redis.conf:/etc/redis/redis.conf # 关联本地/docker/redis/redis.conf文件到容器中/etc/redis/redis.conf,同样,前为本地
-v /docker/redis/data:/data # 关联本地/docker/redis/data到容器内/data目录,此为存放redis数据的目录,为方便以后升级redis,而数据可以留存
-d redis # 后台启动,使用此方式启动,则redis.conf中daemonize必须设置为no,否则会无法启动
redis-server /etc/redis/redis.conf # 在容器内启动redis-server的命令,主要是为了加载配置
给予脚本执行权限
sudo chmod 777 /docker/redis/redis.bash
启动容器
/docker/redis/redis.bash
# 查看是否已启动
docker ps
# 如果无法启动或者docker ps中无对应内容,将bash中命令复制出来,删除-d参数启动,查看报错信息
# 如需访问容器,可使用
docker exec -it redis bash
# 或直接使用redis-cli访问容器内redis
docker exec -it redis redis-cli