这是我参与「第四届青训营 」笔记创作活动的的第11天
这篇笔记主要是解决我们在开发项目的过程中需要准备的一些前置开发准备,例如数据库,后端接口的部署等等,我们这边的接口部署在云服务器上,因为学生云服务器价格便宜,相对性能也不是很好,但是我们的数据上报接口的访问量又比较大,所以我们打算通过量变的方式来解决质变。然后部署集群又是件很麻烦的事儿,所以我们就采用了docker的方式,下面是学习笔记
一、docker的思想:
1、集装箱: 会将所有需要的内容放到不同的集装箱中,谁需要这个环境,就直接拿到这个集装箱就可以了,
2、标准化:
1、运输的标准化:docker有一个码头,所有上传的集装箱都放在这个码头上,当谁需要某一个环境时,只需要让大海豚去搬运这个集装箱就可以了,
2、命令的标准化: docker提供了一系列命令,帮助我们获取集装箱
3、提供了REST的API,并繁衍了很多图形化界面的操作
3、隔离性:docker在运行集装箱的内容时,会在Linux的内核中单独开辟一块空间,这块空间不会影响到其他程序。
二、docker的安装:
1、安装docker的依赖: yum -y install yum-utils device-mapper-persistent-data lvm2
2、设置docker的下载镜像源:
yum-config-manager --add-repo mirrors.aliyun.com/docker-ce/l…
3、安装docker:yum makecache fast yum -y install docker-ce (需要分别运行)
4、 启动,并设置为开机自动启动,测试
启动Docker服务
systemctl start docker
设置开机自动启动
systemctl enable docker # 开机自动启动docker
systemctl restart docker # 重启dokcer
测试 hello wold
docker run hello-world
三、docker的中央仓库
1、docker官方的中央仓库下载很慢,但是资源最全,因为是在国外
2、我们一般使用蜂巢和阿里云的镜像,
3、在公司内部会采用私服
4、hub.daocloud.io
下面是配置私服:
# 需要在/etc/docker/daemon.json
{ "registry-mirrors":["https://registry.docker-cn.com"] }
# 重启两个服务
systemctl daemon-reload
systemctl restart docker
四、docker镜像操作
1、拉取镜像到本地: docker pull 镜像名称 [版本] 不写版本会拉取一个默认的版本 方括号表示里面的类容可写可不写
拉取时可以去 hub.daocloud.io中寻找合适的版本,然后复制地址即可
docker pull 地址
可能出现的问题,报 :Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?
解决方法:
重启一下容器试试
sudo systemctl start docker
2、查看所有的本地镜像:
docker images
3、删除本地镜像
docker rmi 唯一标识符
删除时可能会报错:
运行中不能被删除,需要先停用,
4、镜像的导入与导出(不规范)
将本地的镜像导出
docker save -o 导出的路径 镜像id
加载本地的镜像文件
docker load -i 镜像文件
修改镜像名称
docker tag 镜像id 新镜像名称:版本
注:今天就到这里,明天继续