制作docker之前,将源指向到阿里云
## 备份原镜像软件源
mv /etc/apt/sources.list /etc/apt/sources.list.bak
## 更改镜像为阿里镜像源
echo "deb http://mirrors.aliyun.com/ubuntu/ trusty main multiverse restricted universe" >> /etc/apt/sources.list &&
echo "deb http://mirrors.aliyun.com/ubuntu/ trusty-backports main multiverse restricted universe" >> /etc/apt/sources.list &&
echo "deb http://mirrors.aliyun.com/ubuntu/ trusty-proposed main multiverse restricted universe" >> /etc/apt/sources.list &&
echo "deb http://mirrors.aliyun.com/ubuntu/ trusty-security main multiverse restricted universe" >> /etc/apt/sources.list &&
echo "deb http://mirrors.aliyun.com/ubuntu/ trusty-updates main multiverse restricted universe" >> /etc/apt/sources.list &&
echo "deb-src http://mirrors.aliyun.com/ubuntu/ trusty main multiverse restricted universe" >> /etc/apt/sources.list &&
echo "deb-src http://mirrors.aliyun.com/ubuntu/ trusty-backports main multiverse restricted universe" >> /etc/apt/sources.list &&
echo "deb-src http://mirrors.aliyun.com/ubuntu/ trusty-proposed main multiverse restricted universe" >> /etc/apt/sources.list &&
echo "deb-src http://mirrors.aliyun.com/ubuntu/ trusty-security main multiverse restricted universe" >> /etc/apt/sources.list &&
echo "deb-src http://mirrors.aliyun.com/ubuntu/ trusty-updates main multiverse restricted universe" >> /etc/apt/sources.list
1、如果容器无法停止,先执行:aa-remove-unknown命令,再执行docker container stop imageId 命令
2、ADD拷贝目录失败:在拷贝文件的时候docker是用“/”来区分目录和文件的,也就是“/root”是被当做根目录文件root,“/root/”才被识别为目录
build镜像命令:
docker build -t bbbmarkservices:v2.0.6 .
3、进入正在运行的容器:sudo docker exec -it 65a2cd69a975 /bin/bash,其中784081ffe273为容器的实例ID(使用命令docker ps获取)
4、停止容器:docker container stop 22e5f34de1f3,其中22e5f34de1f3为容器的ID
5、运行一个容器:docker run -it bibibetter:v2 /bin/bash
(mongodb容器:-d,后台运行容器,并返回容器ID)
docker run -d -e AUTHID="AUTHID" -e MGCOONSTR="mongodb:\/\/localhost:27017" -p 29019:27017 -p 1010:80 -p 1020:9090 -p 1030:22 -v mongo_configdb:/data/configdb -v mongo_db:/data/db -v /root/docker/bbbmarkservices/bgpdir:/www/bbbmarkservices/bgpdir --name bbbmarkservices registry.cn-shenzhen.aliyuncs.com/bibibetter/markservices:latest
6、退出镜像:exit
退出镜像后一般要执行docker ps -l,查看是否还存在后台进程,如果有,执行docker rm ×××,×××为前面命令显示的镜像ID
7、创建一个容器:
(1)在应用程序目录下创建文件Dockerfile,写入docker配置信息
(2)建立docker镜像(注意命令最后有个点符号)docker build -t bibibetter:v6 .
8、中文支持(>>为追加操作)
echo "export LANG="zh_CN.UTF-8"" >> /etc/profile
source /etc/profile
9、制作离线镜像文件
(1)运行镜像
(2)安装必要的软件或删除一些软件
(3)测试镜像中的软件
(4)commit(此时不要停止运行中的镜像):docker commit 4cedf68a2a7c bbbembedder:v1.4.2,其中4cedf68a2a7c 为运行中的镜像实例ID(使用命令docker ps获取),bbbembedder为REPOSITORY,v1.4.2为TAG
(5)save: docker save bbbmarkservices:v2.0.5 |gzip > bbbmarkservices_v2.0.5_images.tar.gz
10、导入镜像
将镜像文件上传到服务器后,执行命令:docker load < /root/bibibetterv6.0_images.tar.gz docker load < bbbmarkservices_v2.0.2_images.tar.gz
11、删除镜像出错
docker rmi 5e90946e8da6
Error response from daemon: conflict: unable to delete 5e90946e8da6 (must be forced) - image is being used by stopped container 4e7c110be289
解决办法:执行以下命令删除引用的镜像:
docker rm 4e7c110be289
再执行docker rmi 5e90946e8da6
或者加上-f参数强行删除:docker rmi -f 5e90946e8da6
12、发布端口
-p <宿主端口>:<容器端口>
例如:docker run -it -p 20180:80 -p 20181:8080 -p 20182:8976 --name containerName image:tag
13、显示当前容器的所有状态
docker ps -l
apt-get -y install openssh-server
ssh -l root 192.168.108.60 -p 1030
14、无法删除镜像
Error response from daemon: conflict: unable to delete 6ec9a5a0fc9f (cannot be forced) - image has dependent child images# 6ec9a5a0fc9f为镜像ID
列出依赖:
docker image inspect --format='{{.RepoTags}} {{.Id}} {{.Parent}}' $(docker image ls -q --filter since=6ec9a5a0fc9f)
针对列表中的执行:
docker rmi **** #其中***为列表中的sha256值
15、docker启动方式
(1)docker run -it -p 3030:3030 --name mykafka landoop/fast-data-dev
这种方式,可以通过使用CTRL+C停止它(但没有删除),然后使用以下命令启动:
docker start mykafka
(2)docker run -d -p 3030:3030 --name mykafka landoop/fast-data-dev
这种方式在后台启动,这种情况下只有用stop来停止它
(3)docker run --rm -it -v /path/to/local/directory:/tmp landoop/fast-data-dev
这种方式可以跨container来保持数据:将kafka和zookeeper文件保持好。文件夹/path/to/local/directory必须对kafka和zookeeper可写(chmod 0777),以用户nobody运行
brokers将数据保存在/tmp/kafka-logs,zookeeper将数据保存在/tmp/zookeeper
16、升级glibc
ln -s /opt/glibc-2.29/lib/libc-2.29.so.6 /lib/x86_64-linux-gnu/libm.so.6
- 重要更新说明
- linechain发布
- linechain新版设计
- 引言一
- 引言二
- 引言三
- vs-code设置及开发环境设置
- BoltDB数据库应用
- 关于Go语言、VS-code的一些Tips
- 区块链的架构
- 网络通信与区块链
- 单元测试
- 比特币脚本语言
- 关于区块链的一些概念
- 区块链组件
- 区块链第一版:基本原型
- 区块链第二版:增加工作量证明
- 区块链第三版:持久化
- 区块链第四版:交易
- 区块链第五版:实现钱包
- 区块链第六版:实现UTXO集
- 区块链第七版:网络
- 阶段小结
- 区块链第八版:P2P
- P2P网络架构
- 区块链网络层
- P2P区块链最简体验
- libp2p建立P2P网络的关键概念
- 区块链结构层设计与实现
- 用户交互层设计与实现
- 网络层设计与实现
- 建立节点发现机制
- 向区块链网络请求区块信息
- 向区块链网络发布消息
- 运行区块链
- LineChain
- 系统运行流程
- Multihash
- 区块链网络的节点发现机制深入探讨
- DHT
- Bootstrap
- 连接到所有引导节点
- Advertise
- 搜索其它peers
- 连接到搜到的其它peers
- 区块链网络的消息订发布-订阅机制深入探讨
- LineChain:适用于智能合约编程的脚本语言支持
- LineChain:解决分叉问题
- LineChain:多重签名
- libp2p升级到v0.22版本
- 以太坊基础
- 重温以太坊的树结构
- 世界状态树
- (智能合约)账户存储树
- 交易树
- 交易收据树
- 小结
- 以太坊的存储结构
- 以太坊状态数据库
- MPT
- 以太坊POW共识算法
- 智能合约存储
- Polygon Edge
- block结构
- transaction数据结构
- 数据结构小结
- 关于本区块链的一些说明
- UML工具-PlantUML
- libp2p介绍
- JSON-RPC
- docker制作:启动多个应用系统
- Dockerfile
- docker-entrypoint.sh
- supervisord.conf
- docker run
- nginx.conf
- docker基础操作整理
- jupyter计算交互环境
- git技巧一
- git技巧二
- 使用github项目的最佳实践
- windows下package管理工具