doker基本使用
Docker与虚拟机的区别

- docker和虚拟机最大的不同,docker共用宿主机的内核,虚拟机中每个虚拟机中有单独的内核虚拟出来,如上图所示;
- docker不能做后端兼容性测试,因为其没有独立的虚拟内核
- 在系统上操作的任何东西都不是直接调用内核的,都需要经过系统调用,使用docker安装了操作系统的镜像软件,感觉像是在操作系统上运行,因此即使用的是Centos镜像,内核也有可能是Ubantu的,如下图所示:

Docker的优缺点
优点
- 轻量级:因为docker不用虚拟化内核,直接共享宿主机的内核,所以节省了很多资源,在同样的资源下可以启动更多的软件,同时启动速度也更快
缺点
- 优点即缺点: docker的优点也是它的缺点,正是因为所有的容器都共享一个内核,如果其中一个容器将内核给"搞坏了",那所有的容器就都无法正常工作了
Docker的隔离-三项关键技术
- NameSpace
每启动一个docker进程就会分配一个网络名称空间,进行网络的隔离 - 联合文件系统
能够给每一个容器提供单独的视图,达到文件目录的隔离,这样就不会访问到其他容器的文件 - Cgroups
资源隔离,限定当前进程使用资源大小,达到资源的隔离
镜像管理命令
- docker pull {image_name} 拉取镜像
- docker push {image_name} 推送镜像
- docker images查看当前机器的所有镜像
- docker rmi {image_name} 删除当前机器的⼀镜像
- docker tag {source_images_name:tag your_image_name:tag} 为一个镜像打tag
- docker save {image_name} > {new_image_name}.tar 将一个镜像打包成一个tar包,可供无网络设备使用
- docker load < {image_name}.tar 解压一个镜像tar包
容器管理
- docker run --name={your_name} --d {image_name} 运行容器
- docker ps -a 查看当前所有容器
- docker stop {container_name} 停止容器
- docker kill (container_name) 杀死容器
- docker rm -f {container_name} 强制删除容器
- docker start {container_name} 启动容器
- docker restart {container_name} 重启容器
- sudo docker cp host_path containerID:container_path 从主机复制到容器
- sudo docker cp containerID:container_path host_path 从容器复制到主机
容器运行命令的一些参数
- --name 指定容器名称
- -d 后台运行
- -port 指定端⼝映射规则
- --network 指定容器器运行的⽹路模式
- -v 指定需要挂载的数据卷
- -env 指定需要传递给容器的环境变量
查看信息相关
- docker logs -f {容器名称} 查看容器⽇日志
- docker info 查看docker服务的信息
- docker inspect {容器名称} 查看容器的元数据
docker搭建Jenkins时区问题
- 1.通过dcoker exec -it jenkins bash 进入Jenkins容器 ,执行:echo 'Asia/Shanghai' > /etc/timezone
- 2.启动参数加--env JAVA_OPTS="-Duser.timezone=GMT+08"
docker run --name myjenkins -itd -p 8001:8080 -p 50000:50000 -v /home/test/jenkins_home:/var/jenkins_home --env JAVA_OPTS="-Duser.timezone=GMT+08" jenkins
/home/test/jenkins_home 是本地新建的目录,如果在Mac需要给设置权限,chmod 777 /home/test/jenkins_home
注意挂载权限:sudo chown -R 1000:1000 /home/test/jenkins_home
需要修改下目录权限, 因为当映射本地数据卷时,/home/test/ jenkins_home目录的拥有者为root用户,而容器中jenkins user的uid为1000
sudo chown -R 1000 /home/test/jenkins_home/
搭建MySQL
docker run --name some-mysql -v /hometest/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=1qaz9ol. -p 8888:3306 -d mysql:5.7
其中1qaz9ol. 为数据库root的密码
selenium远程部署
1. docker pull selenium/node-chrome-debug:3.7.1-beryllium
2. docker pull selenium/hub:3.7.1-beryllium
docker run --name=hub -p 5001:4444 -e GRID_TIMEOUT=0 -e GRID_THROW_ON_CAPABILITY_NOT_PRESENT=true -e GRID_NEW_SESSION_WAIT_TIMEOUT=-1 -e GRID_BROWSER_TIMEOUT=15000 -e GRID_TIMEOUT=30000 -e GRID_CLEAN_UP_CYCLE=30000 -d selenium/hub:3.7.1- beryllium
docker run --name=chrome -p 5902:5900 -e NODE_MAX_INSTANCES=6 -e NODE_MAX_SESSION=6 -e NODE_REGISTER_CYCLE=5000 -e DBUS_SESSION_BUS_ADDRESS=/dev/null -v /dev/shm:/dev/shm --link hub -d selenium/node-chrome-debug:3.7.1-beryllium
node_exporter监控系统资源
后台启动 nohup ./node_exporter >>node_exporter.log 2>&1 &
测试脚本
from threading import Thread
from selenium import webdriver
from time import sleep, ctime
# 测试用例
def baidu(search=None):
# print('start:%s,' % browser)
# print('browser:%s' % browser)
# if browser == 'chrome':
# driver = webdriver.Chrome()
# elif browser == 'firefox':
# driver = webdriver.Firefox()
# else:
firefox_capabilities = {
"browserName": "chrome",
"version": "",
"platform": "ANY",
"javascriptEnabled": True,
"marionette": True,
}
browser = webdriver.Remote("http://119.3.89.184:5001/wd/hub",
desired_capabilities=firefox_capabilities) # 注意端口号4444是我们上文中映射的宿主机端口号
# browser.get("http://www.baidu.com")
# driver = webdriver.Chrome()
# print('参数有误')
browser.get('http://www.baidu.com')
browser.find_element_by_id('kw').send_keys(search)
browser.find_element_by_id('su').click()
sleep(3)
browser.quit()
if __name__ == '__main__':
print("主线程开始======{}".format(ctime()))
lites = {
'chrome': 'threading',
'firefox': 'python',
'java': 'java'
} # 启动浏览器,指定每个浏览器搜索的内容
threads = []
files = range(len(lites))
# 创建多线程
for search in lites.values(): # 字典循环
print(search)
t = Thread(target=baidu, args=(search,))
threads.append(t)
# 启动多线程
for t in files:
threads[t].start()
for t in files:
threads[t].join()
print("主线程结束======{}".format(ctime()))
搭建prometheus
docker run --name prometheus -d -p 9090:9090 -v `pwd`/prometheus.yml:/etc/prometheus/prometheus.yml prom/prometheus
prometheus.yml文件
global:
scrape_interval: 15s
evaluation_interval: 15s
rule_files:
- rules/*.rules
scrape_configs:
- job_name: 'prometheus'
static_configs:
- targets: ['localhost:9090']
- job_name: 'node_exporter'
static_configs:
- targets: [ '192.168.0.103:9100']
- job_name: 'mysql'
static_configs:
- targets: ['docker.testing-studio.com:9104', '119.3.89.184:9104']
启动grafana
docker run --name grafana -d -p 8000:3000 grafana/grafana
启动mysqld-exporter
docker run -d --name mysql-exporter -p 9104:9104 -e DATA_SOURCE_NAME="root:1qaz9ol.@(docker.testing-studio.com :8888)/mysql" prom/mysqld-exporter
doker基本使用的更多相关文章
- [doker]ubuntu18安装doker
ubuntu安装doker很简单,分4个步骤: Step1:更新资源库并安装apt-transprot-https软件包. 在安装Docker前, 首拉取最新的软件资源库 wangju@wangju- ...
- Doker安装日志,留个记录而已
tianye@ubuntu:/usr/share$ wget -qO- https://get.docker.com/ | sh # Executing docker install script, ...
- doker学习笔记
1.获取镜像: docker pull mysql 2,查看已安装的镜像: docker image 3,运行: 查看docker运行:docker info(docker run ubuntu ec ...
- Doker学习笔记之一:安装
基于Ubuntu16.04LTS 第一步:通过脚本进行安装 $ curl -sSL https://get.docker.com/ | sh 或者选择国内的DaoCloud安装脚本 $ curl -s ...
- linux 下安装doker centeros6.5
通过 cat /proc/version .uname [root@192.168.1.1 ~]# cat /proc/version Linux version 2.6.32-279.el6.x86 ...
- doker 笔记(1) 架构
Docker 的核心组件包括: Docker 客户端 - Client Docker 服务器 - Docker daemon Docker 镜像 - Image Registry Docker 容器 ...
- Doker容器之间连接
第一个应用容器 $ sudo docker run --name=mysql_client1 --link=mysql_server:db -t -i kongxx/mysql_client /usr ...
- doker基础
去 Docker Hub 上拉取一个叫 hello-world 的集装箱docker pull hello-world然后让这个集装箱跑起来docker run hello-world查看本机所安装的 ...
- Doker容器部署Tomcat服务器
1.拉取tomcat服务镜像文件 root@ubuntu:~# docker pull registry.cn-hangzhou.aliyuncs.com/xxxx/xxxxx:web web: Pu ...
- Doker部署Jmeter(一) 目标服务器部署Jmeter监控容器
用jmeter插件监控服务器性能之前也有提到:https://www.cnblogs.com/betterbb/p/11285022.html 这里主要记录一下docker上的部署,所需的3个插件可以 ...
随机推荐
- python中的n次方表示法 **n
例题:计算2的n次方,n由用户输入(N次方用**表示)# n=eval(input('手动输入n的值:')) #个人感觉,不确定是int还是float时,用eval来表示,eval后面接表达式# pr ...
- [LeetCode]Sql系列4
##题目1 626. 换座位 小美是一所中学的信息科技老师,她有一张 seat 座位表,平时用来储存学生名字和与他们相对应的座位 id. 其中纵列的 id 是连续递增的 小美想改变相邻俩学生的座位. ...
- [程序员代码面试指南]递归和动态规划-换钱的方法数(DP,完全背包)
题目描述 给定arr,arr中所有的值都为正数且不重复.每个值代表一种面值的货币,每种面值的货币可以使用任意张,再给定一个整数aim,求组成aim的方法数. 解题思路 完全背包 和"求换钱的 ...
- 操作系统(AIX)双因素身份认证解决方案-中科恒伦CKEY DAS
一.场景分析 操作系统是管理计算机硬件与软件资源的计算机程序,用于工作中的进程管理.存储管理.设备管理.文件管理.作业管理等,十分重要,安全等级极高! 二.问题分析 1.密码设置简单,非常容易被撞 ...
- 面试的加分项:懂点 Nginx 反向代理与负载均衡
学到老活到老 前端圈一直很新,一直要不停的学习,而且在进入大厂的路上,还要求熟悉一门后台语言等等.用一句别人开玩笑的话来说,java十年前的技术现在还能用,而前端的技术就不是这样的了 突然想起了d ...
- 静态代理、jdk动态代理、cglib动态代理
一.静态代理 Subject:抽象主题角色,抽象主题类可以是抽象类,也可以是接口,是一个最普通的业务类型定义,无特殊要求. RealSubject:具体主题角色,也叫被委托角色.被代理角色.是业务逻辑 ...
- ZooKeeper学习(一)了解ZooKeeper
一.什么是ZooKeeper ZooKeeper主要服务于分布式系统,可以用ZooKeeper来做:统一配置管理.统一命名服务.分布式锁.集群管理. 使用分布式系统就无法避免对节点管理的问题(需要实时 ...
- pwnable.kr-coin1-witeup
是一个小游戏,会给100堆小硬币,在每堆硬币中找到假币(重量为9,其他重量为10),其中每堆硬币都设置了金币数和固定的尝试次数. 思路是:在每堆硬币中,在有限的尝试次数中对硬币通过二分法计算硬币重量不 ...
- Spring--AOP的见解
AOP是指面向切面编程,与JAVA中的动态代理有很深的渊源. 在使用Spring框架时,AOP编程能简化很多繁杂的步骤,精简代码. 切面:横切关注点(跨越程序中多个模块的功能),被模块化的特殊对象,也 ...
- 每日一个知识点:Volatile 和 CAS 的弊端之总线风暴
每日一个知识点系列的目的是针对某一个知识点进行概括性总结,可在一分钟内完成知识点的阅读理解,此处不涉及详细的原理性解读. 一.什么是总线风暴 总线风暴,听着真是一个帅气的词语,但如果发生在你的系统上那 ...