麒麟系统离线安装docker和docker-compose
最近需要在麒麟系统安装emqx,由于emqx没有麒麟系统的安装包且源码编译依赖版本较难管理,因此采用docker容器化部署,现在回忆总结一下docker和docker-compose的离线安装步骤。这里是麒麟系统docker离线部署教程回忆版:https://www.cnblogs.com/scales123/p/19279440
1 准备工作
我安装的操作系统是麒麟V4及V10,aarch64架构
1.1 查看操作系统
// 查看系统版本
uname -a
// 查看系统架构
uname -m1.2 下载安装包
我使用的docker版本是:docker-20.10.7.tgz,docker-compose版本是v2.17.2,我整理的下载资源:通过网盘分享的文件:docker_20.10.17安装包.rar
链接: https://pan.baidu.com/s/1LbFJDHMTcpblSUAiMpfteQ?pwd=1234 提取码: 1234
选择aarch64架构
选择对应的版本
docker:https://download.docker.com/linux/static/stable/aarch64/
dcoker-compose: https://github.com/docker/compose/releases
找到docker的对应版本,在Assets里选择相应架构的安装包
1.3 准备docker.service文件
docker.service
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
After=network-online.target firewalld.service
Wants=network-online.target
Type=notify
# the default is not to use systemd for cgroups because the delegate issues still
# exists and systemd currently does not support the cgroup feature set required
# for containers run by docker
ExecStart=/usr/bin/dockerd
ExecReload=/bin/kill -s HUP $MAINPID
# Having non-zero Limit*s causes performance problems due to accounting overhead
# in the kernel. We recommend using cgroups to do container-local accounting.
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
# Uncomment TasksMax if your systemd version supports it.
# Only systemd 226 and above support this version.
#TasksMax=infinity
TimeoutStartSec=0
# set delegate yes so that systemd does not reset the cgroups of docker containers
Delegate=yes
# kill only the docker process, not all processes in the cgroup
KillMode=process
# restart the docker process if it exits prematurely
Restart=on-failure
StartLimitBurst=3
StartLimitInterval=60s
WantedBy=multi-user.target3 安装docker和docker-compose
以下命令逐步执行
// 将安装包存放到/opt/docker
scp -r 本地存放目录 用户名@remote_host:/opt/docker
// 进入安装文件存放目录
cd /opt/docker
// 解压 docker 到当前目录
tar -xvf docker-20.10.7.tgz
// 将 docker 文件移动到 /usr/bin 目录下
cp -p docker/* /usr/bin
// 将 docker-compose 文件复制到 /usr/local/bin/ 目录下,并重命名为 docker-compose
cp docker-compose-linux-aarch64 /usr/local/bin/docker-compose
// 设置 docker-compose 文件权限
chmod +x /usr/local/bin/docker-compose
// 将 docker.service 移到 /etc/systemd/system/ 目录
cp docker.service /etc/systemd/system/
// 设置 docker.service 文件权限
chmod +x /etc/systemd/system/docker.service
// 重新加载配置文件
systemctl daemon-reload
// 启动docker
systemctl start docker
// 设置 docker 开机自启
systemctl enable docker.service
// 验证docker是否安装成功
docker -v
// 验证docker-compose是否安装成功
docker-compose -v4 docker常用命令
4.1 镜像相关命令
创建容器的基础。
命令说明docker images列出本地所有镜像docker search 从 Docker Hub 搜索镜像docker pull [:标签]下载镜像(不指定标签则默认为 latest)docker rmi 删除一个本地镜像docker rmi $(docker images -q)删除所有本地镜像docker image prune删除所有未被使用的镜像(悬空镜像)docker build -t [:标签] .根据当前目录的 Dockerfile 构建镜像docker history 查看镜像的构建历史层docker tag给镜像打一个新的标签示例:
docker pull nginx:alpine
docker images
docker rmi 5dbe117b5cf4
docker build -t my-app:v1 .4.2 容器生命周期管理
用于创建、启动、停止、删除容器。
命令说明docker run [选项] 创建并启动一个新容器docker create 只创建容器,但不启动docker start 启动一个已存在的容器docker stop 优雅地停止一个运行中的容器docker restart 重启容器docker kill 强制立即停止一个容器docker pause 暂停容器内的所有进程docker unpause 恢复容器内被暂停的进程docker rm 删除一个已停止的容器docker rm $(docker ps -aq)删除所有已停止的容器docker container prune删除所有已停止的容器docker run 常用选项:
[*]-d:后台运行(守护进程)
[*]-it:交互模式运行(通常与 /bin/bash 结合)
[*]--name:为容器指定一个名称
[*]-p ::映射端口
[*]-v ::挂载数据卷
[*]--rm:容器退出时自动删除(用于测试)
[*]-e:设置环境变量
示例:
# 后台运行一个名为 my-nginx 的容器,并映射端口
docker run -d --name my-nginx -p 80:80 nginx
# 交互式运行一个 Ubuntu 容器,并进入其终端
docker run -it ubuntu /bin/bash
# 运行一个一次性容器,退出后自动删除
docker run --rm -it alpine /bin/sh4.3 容器信息查看与操作
用于查看和与正在运行的容器交互。
命令说明docker ps列出正在运行的容器docker ps -a列出所有容器(包括已停止的)docker logs 查看容器的日志输出docker logs -f 实时跟踪(Follow)容器日志docker exec -it在正在运行的容器中执行命令docker attach 连接到正在运行的容器的主进程(不推荐,容易导致容器停止)docker top 查看容器内运行的进程docker inspect 查看容器的底层详细信息(JSON格式)docker stats动态显示所有容器的资源使用情况(CPU、内存等)docker diff 检查容器文件系统相对于镜像的更改示例:
docker ps -a
docker logs -f my-nginx
docker exec -it my-nginx /bin/bash# 进入容器的 Shell
docker inspect my-nginx | grep IPAddress# 查看容器的 IP 地址4.4 数据卷与网络管理
用于管理容器的持久化数据和网络连接。
命令说明docker volume ls列出所有数据卷docker volume create 创建一个数据卷docker volume inspect 查看数据卷的详细信息docker volume rm 删除一个数据卷docker volume prune删除所有未被使用的数据卷docker network ls列出所有网络docker network create 创建一个自定义网络docker network connect将容器连接到指定网络docker network inspect 查看网络的详细信息示例:
# 创建一个数据卷,并运行一个使用该卷的容器
docker volume create my-data
docker run -v my-data:/data --name data-container alpine
# 创建一个自定义的桥接网络,让容器间可以通过容器名通信
docker network create my-app-network
docker run -d --name mysql --network my-app-network mysql
docker run -d --name webapp --network my-app-network my-web-app4.5 Docker Compose 常用命令
用于管理和运行多容器应用。
命令说明docker-compose up创建并启动所有服务(在前台运行)docker-compose up -d创建并启动所有服务(在后台运行)docker-compose down停止并删除所有容器、网络docker-compose stop停止所有服务,但不删除容器docker-compose start启动已存在的服务docker-compose restart重启所有服务docker-compose ps列出 Compose 文件定义的所有容器docker-compose logs查看所有服务的日志docker-compose logs -f 实时跟踪特定服务的日志docker-compose exec在指定的服务容器中执行命令docker-compose build构建或重新构建服务镜像docker-compose pull下载服务镜像5 参考
https://blog.csdn.net/qq_23845083/article/details/130768859
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! 谢谢分享,辛苦了
页:
[1]