docker 快速实战指南

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: docker 快速上手使用指南

docker 快速上手使用指南


作为一个对技术有追求的程序员,购买了一个自己的阿里云机器,但中途历经多次数据和环境的迁移,发现多次配置阿里云环境太费事了,最终下定决心把一些基础服务 docker 化。查了一些资料,也总结了一些常用的docker 工具的配置方法,这里和大家分享一下,希望能对大家有所帮助,有问题欢迎 留言讨论~


Docker是基于Go语言进行开发实现的一个开源的应用容器引擎,每个容器内运行着一个应用,不同的容器相互隔离,容器之间也可以通过网络互相通信。docker 作为一种轻量级的沙盒,以其一次部署多地运行和管理简单、快速方便部署等优点,可以很方便的解决业务部署上的痛点问题而大受欢迎。对于docker的原理这里不在展开,本文仅仅从docker的快速上手使用方面展开阐述。

(一) docker 的安装与基础命令

(1.1) docker 安装

windows下使用docker的话,需要下载docker for windows 的安装文件,安装后将bin文件配置到环境变量中,就可以通过cmd使用命令行对容器进行操作和管理了,当然windows下也可以通过桌面版UI进行管理。


因为docker大多数在linux服务端使用,这里仅仅详细介绍linux/ubuntu 下的安装过程:

安装命令(使用阿里云镜像):

sudo apt-get update && sudo apt-get install -y apt-transport-https ca-certificates curl software-properties-common && curl -fsSL https:``//download``.[docker.com](http://docker.com/)``/linux/ubuntu/gpg | sudo apt-key add - && sudo add-apt-repository "deb [arch=amd64] [http://mirrors.aliyun.com/docker-ce/linux/ubuntu](http://mirrors.aliyun.com/docker-ce/linux/ubuntu) $(lsb_release -cs) stable" && sudo apt-get update && sudo apt-get install -y docker-ce

一条命令就可以搞定安装,不过安装可能需要一些时间,等着就行。


在使用过程中,当需要查找某个镜像的时候,我们可以去docker中央仓库:https://hub.docker.com/ 查看,从中我们可以看到该名称镜像历史的release的版本,我们可以根据需求选择自己需要的版本。

(1.2) docker常用管理命令

(1) 拉取某个镜像

docker pull xxxx

(2)查看镜像与删除镜像


查看所有镜像:docker images


删除镜像 : docker rmi xxxx


注意:删除镜像前必须先停用、删除该镜像产生的实例


(3) 查看与删除实例


查看所有实例: docker ps -a


查看activate实例: docker ps


删除实例: docker rm xxx


(4)根据镜像创造docker 实例,这里以nginx为例

docker run --name nginx -p 80:80 -v /root/docker_conf/nginx/nginx.conf:/etc/nginx/nginx.conf -d docker.io/nginx

其中: -name是镜像的名称, -p 是端口映射, -v 是绑定一个卷, 我们可以把自己的文件目录映射到镜像内部目录, 冒号前面为自己的实际机器, :后面是对应镜像的目录。


(5) 当docker 启动失败的时候debug原因:

docker logs xxID

(6) 进入实例


根据上面的命令创建的实例之后,如果成功的话会默认启动实例,我们可以使用下列命令进入到该实例内部:

docker exec -it nginx bash

(7) 复制文件到实例内部系统

docker cp my.cnf mysql5.7:/etc/mysql/my.cnf

(8) 实例内系统安装软件


实例内也是一个操作系统,我们可以安装需要使用的程序:

apt update

例如安装vim命令 : apt install vim


(9) 停止和启动docker 实例


docker start xxx
docker stop xxx

(10) 卸载docker

yum remove docker-ce

删除镜像、容器、配置文件等内容:

rm -rf /var/lib/docker

(二) docker 资源管理命令

docker 镜像在很多时候会耗占比较多的内存和cpu, 甚至某个镜像被用来挖矿的情况下, cpu会达到100%(都是血与泪的实践经历啊), 所以我们可以使用下面的命令来限制性设置某个实例的内存与cpu占用量。


(1) docker 各个镜像资源使用情况查看(包括cpu和内存):

docker stats

(2) 限制docker 内存

docker update -m 20M --memory-reservation 20M --memory-swap 20M nginx

(6)限制docker cpu

docker update --cpu-period=100000 --cpu-quota=20000 nginx

在每 100 毫秒的时间里,运行进程使用的 CPU 时间最多为 20 毫秒,这里仅仅考虑百分比。

(三) docker 常用软件管理

在这里,作者分享一些自己常用的一些docker 软件的配置方法 ,包括wiz note , mysql, redis, nginx, gitea , graph learn 等。以后会不断的更新,在使用过程中,如果遇到任何问题,欢迎去: 算法全栈之路 公众号 和作者讨论 ~

(3.1) docker 部署私有的笔记服务 wiznote

作为一个对写代码有追求的程序员,有一个自己用起来顺手的笔记服务是必不可少的,作者经过大量的筛选,目前主要在使用的就是wiznote 这个软件,个人用户使用5个账号内免费,并且个人功能上的需求完全可以满足,使用docker部署也非常简单便利。


(1) 部署过程如下:

docker run --name wiz --restart=always -it -d -v /root/docker_conf/wiz_wiki_dat:/wiz/storage -v /etc/localtime:/etc/localtime -p 9191:80 -p 9269:9269/udp wiznote/wizserve

然后我们访问 http://ip:9191 网址即可以访问我们自己的笔记后端服务了。

初始账号: admin@wiz.cn, 密码:123456,

输入后记得自行进行修改啊,否则可能导致被他人登陆。

(3.2) docker 部署 mysql

(1)docker 部署 mysql


参考wiki: https://blog.csdn.net/weixin_43888891/article/details/122518719

docker pull mysql:5.7
docker run -itd --name mysql5.7 --restart=always -p 3306:3306 -e MYSQL_ROOT_PASSWORD=you_mysql_pwd docker.io/mysql:5.7

进入docker 内部: docker exec -it mysql5.7 bash

(2) 配置数据库可以远程访问

docker exec -it mysql5.7 bash
grant all on *.* to root@'%' identified by 'you_mysql_pwd' with grant option;

(3) 优化docker MySQL 配置


更新 my.cnf 文件

[mysqld]
max_connect_errors = 1000
lower_case_table_names = 1
performance_schema_max_table_instances = 200
table_definition_cache = 100
table_open_cache = 100
innodb_buffer_pool_size=2M
performance_schema=off

更新 docker.cnf 文件

skip-host-cache
skip-name-resolve

(4)覆盖docker 内部文件配置

docker cp docker.cnf  mysql5.7:/etc/mysql/conf.d/docker.cnf
docker cp my.cnf  mysql5.7:/etc/mysql/my.cnf

(5) 限制docker MYSQL 内存和cpu使用

docker update -m 800M --memory-reservation 800M --memory-swap 800M mysql5.7
docker update  --cpu-period=100000 --cpu-quota=20000 mysql5.7

(3.3)docker 部署 redis

(1) docker 使用redis

docker run --name redis -p 6379:6379 -v /root/docker_conf/redis/redis.conf:/etc/redis/redis.conf -d redis redis-server /etc/redis/redis.conf

我们可以把redis常用的配置文件放在 /root/docker_conf/redis/redis.conf 这个路径下。

(2) 外面访问容器里的redis服务

docker exec -it redis redis-cli

(3) 限制redis内存访问

docker update -m 50M --memory-reservation 50M --memory-swap 50M redis

然后我们就可以通过 ip: 6379 端口访问我们的redis 服务了。


(3.4) docker 部署 nginx

(1) docker 使用 nginx

docker pull nginx
// 本机卷映射 nginx卷
docker run --name nginx -p 80:80 -v /root/docker_conf/nginx/nginx.conf:/etc/nginx/nginx.conf -d docker.io/nginx

(2) 限制docker 使用内存

docker update -m 50M --memory-reservation 50M --memory-swap 50M nginx

注意,使用docker 之后,映射的服务IP应该改成外部IP,在使用127.0.0.1会报错。


(3)配置nginx conf

/root/docker_conf/nginx下nginx.conf

这样我们修改本机器上的/root/docker_conf/nginx/nginx.conf 路径下的配置文件,就可以直接影响docker nginx服务的配置了。


然后我们就可以通过 http://ip:80 端口访问我们的 nginx 服务了。


(3.5) docker 部署 gitea

在很多时候我们会需要部署我们自己的git版本管理仓库,可以使用gitea 这个开源版本库,非常好用,使用docker部署也非常简单。

(1) 拉取gitea仓库

docker pull gitea/gitea

(2) 启动gitea 实例与服务

docker run -d --privileged=true --restart=always --name=gitea -p 20022:22 -p 3000:3000 -v /root/docker_conf/gitea:/data gitea/gitea:latest

在下面我们就可以使用 http://ip:3000 去访问我们的git服务了。


(3.6) docker 部署使用图机器学习框架graph learn

注意python版本:python2.7


(1) 安装软件

pip2 install tensorflow==1.13.1

(2) 拉取 graph learn镜像

sudo docker pull graphlearn/graphlearn:1.0.0-tensorflow1.13.0rc1-cpu

(3) 运行 graph learn 实例

sudo docker run -d -it --name graph_idml -v /home/local_machine/workspace:/root/workspace graphlearn/graph-learn

(4) 进入graph leanr 实例

sudo docker exec -it 6c1c2dda75f9 /bin/bash

(5) 开始使用 graph learn 框架训练图机器学习模型


在这里,我们把训练模型需要的数据下载到 /home/local_machine/workspace 这个路径下,然后进入到镜像里面,使用镜像的graph learn 环境,训练自己的模型,输入数据和执行的代码选择 /root/workspace 这个路径。

python train_unsupervised.py

(四) docker 镜像文件保存与加载

(1) 保存docker 镜像文件到本地:

docker save nginx >./nginx.tar

(2) 在另一台主机加载本地文件到镜像 :

docker load < nginx.tar

然后看 docker images ,就能看到该镜像 ,但是名字和标签都是none


(3)执行完上述语句后,查看本地镜像,会看到新加载的镜像名字和标签都是none,利用该镜像的id对名字和标签重新命名即可:


指令:docker tag 镜像id 镜像名:标签

docker tag 172825a55619 confluence6.12_cracked:0.1

(4) 启动镜像

docker run -it --name nginx 172825a55619 /bin/bash

(五) docker 镜像文件的提交与上传到中央仓库

很多时候,我们会需要在已有的镜像上进行一些自定义修改,然后重新打包上传自己的镜像供别人使用,我们可以使用下面的流程来上传自己新打包的镜像到中央仓库。


(5.1) 官网账号注册


首先我们先到docker官网注册一个账号,这样我们才能将制作好的镜像上传到docker仓库,


打开 https://hub.docker.com/


(5.2) 提交自己要上传的镜像

docker commit Container_name yourdockerhub/nginx:latest

注意:commit 对包名命名有要求,Container_name 容器名称,yourdockerhub改成自己的账号,否则无法上传


(5.3) 登录到远程docker仓库(输入自己注册的账号和密码)

docker login

(5.4) 上传至docker云端

docker push yourdockerhub/nginx:latest

注意: 这里push 对包名命名有要求,yourdockerhub改成自己的账号,否则无法上传

上传成功了就可以在中央仓库你的账号下搜到你刚上传的镜像了。


到这里,docker 快速上手使用指南已经结束了。


码字不易,觉得有收获就点赞、分享、再看三连吧~


算法全栈之路


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
3天前
|
分布式计算 Java Linux
【深入浅出Docker原理及实战】「原理实战体系」零基础+全方位带你学习探索Docker容器开发实战指南(Dockerfile使用手册)
Docker 是一套构建在 Linux 内核之上的高级工具,旨在帮助开发人员和运维人员更轻松地交付应用程序和依赖关系,实现跨系统和跨主机的部署。使用安全且轻量级的容器环境来实现这一目标。容器可以手动创建,也可以通过编写 Dockerfile 自动创建。开发人员和运维人员可以将应用程序及其依赖打包到容器中,实现应用程序的可移植性和环境一致性。
132 5
【深入浅出Docker原理及实战】「原理实战体系」零基础+全方位带你学习探索Docker容器开发实战指南(Dockerfile使用手册)
|
3天前
|
监控 安全 Cloud Native
【云原生之Docker实战】使用Docker部署Ward服务器监控工具
【5月更文挑战第11天】使用Docker部署Ward服务器监控工具
21 3
|
3天前
|
Cloud Native 安全 Linux
【云原生之Docker实战】使用Docker部署mBlog微博系统
【5月更文挑战第10天】使用Docker部署mBlog微博系统
14 2
|
3天前
|
测试技术 持续交付 Docker
Docker in Docker原理与实战
Docker in Docker原理与实战
6 0
|
3天前
|
存储 缓存 监控
【Docker 专栏】Docker 容器性能调优实战
【5月更文挑战第8天】本文探讨了Docker容器的性能调优技巧,包括理解容器性能指标(如CPU、内存、网络和磁盘I/O)并进行相应调优。重点讲述了CPU和内存的限制设置,网络配置优化以及磁盘I/O性能提升方法。通过实例展示了如何解决高CPU使用率问题,强调了根据应用需求进行调优的重要性,以实现更高效、稳定的容器运行。
【Docker 专栏】Docker 容器性能调优实战
|
3天前
|
前端开发 API 数据库
【Docker专栏】Docker Compose实战:编排多容器应用
【5月更文挑战第7天】Docker Compose是Docker的多容器管理工具,通过YAML文件简化多容器应用部署。它能一键启动、停止服务,保证开发、测试和生产环境的一致性。安装后,创建`docker-compose.yml`文件定义服务,如示例中的web和db服务。使用`docker-compose up -d`启动服务,通过`docker-compose ps`、`stop`、`down`和`logs`命令管理服务。
【Docker专栏】Docker Compose实战:编排多容器应用
|
3天前
|
运维 Linux Docker
Docker详解(十一)——Docker容器CPU资源限额实战Docker详解
Docker详解(十一)——Docker容器CPU资源限额实战
30 5
|
3天前
|
Docker 容器
电子好书发您分享《4天实战 轻松玩转docker4天实战 轻松玩转docker》
📚 《4天实战:轻松玩转Docker》电子书分享🚀。通过4天的学习,快速掌握Docker容器技术。阿里云链接:[阅读全书](https://developer.aliyun.com/ebook/7445/20547?spm=a2c6h.26392459.ebook-detail.4.73e72e17w6wZGj)。书中包含丰富实例和图片,助你轻松上手!PNG图像示意。
29 2
|
3天前
|
jenkins Java 持续交付
Jenkins与Docker的自动化CI/CD实战
Jenkins与Docker的自动化CI/CD实战
|
3天前
|
JavaScript 前端开发 Docker
全栈开发实战:结合Python、Vue和Docker进行部署
【4月更文挑战第10天】本文介绍了如何使用Python、Vue.js和Docker进行全栈开发和部署。Python搭配Flask创建后端API,Vue.js构建前端界面,Docker负责应用的容器化部署。通过编写Dockerfile,将Python应用构建成Docker镜像并运行,前端部分使用Vue CLI创建项目并与后端交互。最后,通过Nginx和另一个Dockerfile部署前端应用。这种组合提升了开发效率,保证了应用的可维护性和扩展性,适合不同规模的企业使用。