docker 快速实战指南

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Tair(兼容Redis),内存型 2GB
简介: 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月前
|
Cloud Native 持续交付 Docker
云原生之旅:Docker容器化实战指南
【8月更文挑战第29天】本文将引领你进入云原生技术的世界,以Docker容器化为切入点,深入浅出地介绍如何利用Docker进行应用的打包、部署及管理。我们将通过实际代码示例,一步步展示Docker镜像的构建过程,以及如何运行和管理这些容器。无论你是初学者还是有一定经验的开发者,都能从中获得宝贵的知识和实操经验。
|
23天前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
72 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
1月前
|
存储 应用服务中间件 云计算
深入解析:云计算中的容器化技术——Docker实战指南
【10月更文挑战第14天】深入解析:云计算中的容器化技术——Docker实战指南
55 1
|
2月前
|
Docker 容器
Docker自建仓库之Harbor高可用部署实战篇
关于如何部署Harbor高可用性的实战教程,涵盖了从单机部署到镜像仓库同步的详细步骤。
148 15
Docker自建仓库之Harbor高可用部署实战篇
|
2月前
|
算法 Linux 调度
Docker的资源限制实战篇
本文详细介绍了如何利用Docker对容器的资源进行限制,包括内存和CPU的使用。文章首先概述了资源限制的重要性及其在Linux系统中的实现原理,并强调了不当设置可能导致的风险。接着,通过一系列实战案例展示了如何具体设置容器的内存限制,包括硬性限制、动态调整以及软限制等。最后,文章还提供了限制容器CPU访问的具体方法和示例,如指定容器使用的CPU核心数和基于`--cpu-shares`参数对CPU资源进行分配。通过这些实践,读者可以更好地理解和掌握Docker资源管理技巧。
236 14
Docker的资源限制实战篇
|
2月前
|
存储 数据管理 应用服务中间件
Docker的数据管理实战篇
关于Docker数据管理实战的教程,涵盖了Docker数据卷的使用、特点、场景以及数据卷容器的概念和应用。
66 13
Docker的数据管理实战篇
|
2月前
|
运维 Cloud Native Docker
云原生技术入门:Docker容器化实战
【9月更文挑战第20天】本文将引导你走进云原生技术的世界,通过Docker容器化技术的实战演练,深入理解其背后的原理和应用。我们将一起探索如何在云平台上利用Docker简化部署、扩展和管理应用程序的过程,并揭示这一技术如何改变现代软件的开发和运维模式。
|
2月前
|
Ubuntu Linux Docker
Ubuntu 18.04 安装Docker实战案例
关于如何在Ubuntu 18.04系统上安装Docker的实战案例,包括安装步骤、配置镜像加速以及下载和运行Docker镜像的过程。
356 3
Ubuntu 18.04 安装Docker实战案例
|
2月前
|
存储 Linux Docker
CentOS 7.6安装Docker实战案例及存储引擎和服务进程简介
关于如何在CentOS 7.6上安装Docker、介绍Docker存储引擎以及服务进程关系的实战案例。
139 3
CentOS 7.6安装Docker实战案例及存储引擎和服务进程简介
|
2月前
|
关系型数据库 Linux 虚拟化
Docker入门基础实战
Docker入门基础实战