Docker基础:连接容器

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 本文讲的是Docker基础:连接容器【编者的话】本文是作者学习Docker的笔记,介绍了Docker上的网络,并提供了例子。
本文讲的是Docker基础:连接容器【编者的话】本文是作者学习Docker的笔记,介绍了Docker上的网络,并提供了例子。

【3 天烧脑式容器存储网络训练营 | 深圳站】本次培训以容器存储和网络为主题,包括:Docker Plugin、Docker storage driver、Docker Volume Pulgin、Kubernetes Storage机制、容器网络实现原理和模型、Docker网络实现、网络插件、Calico、Contiv Netplugin、开源企业级镜像仓库Harbor原理及实现等。

简介

这篇文章是 Docker基础 系列的第二篇。 上篇文章中 ,我们讨论了镜像和容器的区别以及几个简单的例子。

这次假设我们有连个容器,我们如何让它俩相互通信。我首先想到的场景是 application-database 间的关系。我将创建下面两个容器:
  • MySQL RDBMS
  • 一个简单的Python脚本,从MySQL容器fetch数据并且打印出来

一个绑定容器的网络

过去连接容器使用 --link 标记,但是它被弃用了。新的方法是使用 network特性 。当我们运行 docker network ls 时会看到:
NETWORK ID      NAME    DRIVER  SCOPE
9872c9881f6e    bridge  bridge  local
6fc119c0ceda    host    host    local
c3fdf8d5c56e    none    null    local 

它们的含义是:
  • bridge:默认网络,所有容器默认连接到它
  • none:没有网络接口
  • host:连接到主机的网络栈,主机和容器间的网络没有隔离

如果想深入了解某个网络,使用 docker network inspect <name> 命令。

控制容器间通信的推荐做法是使用 用户定义网络 ,通过它我们可以方便地创建自己的网络。比如创建一个网络 docker network create my-network 然后查看 docker network ls
NETWORK ID      NAME        DRIVER  SCOPE
9872c9881f6e    bridge      bridge  local
6fc119c0ceda    host        host    local
c3fdf8d5c56e    none        null    local
19671b2b8b20    my-network  bridge  local

这样我们自己定义的网络就创建好并且可以使用了。

MySQL容器

先运行一个 docker run -d --name mysql-server --network my-network -e MYSQL_ROOT_PASSWORD=secret mysql 不同参数的含义分别是:
  • -d,容器与当前进程分离,后台运行
  • **--name--,指定容器名
  • --network,指定容器连接网络
  • -e,设置环境变量

非常简单,我们的容器就运行起来了。现在我们要连接到我们的数据库容器中,创建数据库、表,然后添加些简单的数据。我将演示创建的网络把两个容器连接起来,我需要再运行一个不同的容器来连接到数据库服务器上:
docker run -it --rm --network my-network mysql sh -c 'exec mysql -h"mysql-server" -P"3306" -uroot -p"secret"'

如果一切正常,我们会看到:
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 3
Server version: 5.7.18 MySQL Community Server (GPL)
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>

刚才的命令意思是:
  • -it,运行在交互模式
  • --rm,容器退出后自动删除
  • --network,指定需要连接的网络
  • 然后execMySQL程序和必要的参数连接到数据库服务器。注意,我们用MySQL容器名作为host

下面我们创建一个例子:python脚本连接数据库。首先运行下面命令创建数据库等:
CREATE DATABASE mydb;
USE mydb;
CREATE TABLE person (fname VARCHAR(20), lname VARCHAR(20));
INSERT INTO person(fname, lname) VALUES ('Mick', 'Jagger');

查询脚本

这部分我们会创建自己的镜像,Windows用户需要注意:由于Docker在Windows有些限制,我们的目录和脚本需要放到 C:\Users\<someuser> 目录下。

首先创建目录 C:\Users\myuser\my-script ,然后目录下创建 Dockerfile (是的,不需要扩展名):
FROM python:2

WORKDIR /usr/src/app
RUN pip install MySQL-python
COPY . .

CMD [ "python", "./script.py" ]

简单解释下,这几行分别表示 python:2 基础镜像,设置工作目录,下载依赖,拷贝文件,指定容器执行命令。

然后创建 script.py 文件:
#!/usr/bin/python
import MySQLdb
db = MySQLdb.connect("mysql-server", "root", "secret", "mydb")
cursor = db.cursor()
cursor.execute("SELECT * FROM person")
data = cursor.fetchone()
fname = data[0]
lname = data[1]
print "fname=%s, lname=%s" % (fname, lname)
db.close() 

这个脚本会连接到MySQL数据库,然后查询数据。最后我们构建镜像:
docker build -t my-script .

接着运行镜像:
docker run -it --rm --network my-network my-script

会看到输出:
fname=Mick, lname=Jagger

证明我们的脚本正确运行。

总结

  • --link参数会被弃用
  • 使用新的--network参数
  • 会有默认的network,但是推荐使用自定义网络
  • --name很重要,它指定主机在另一个容器里的可见地址
  • 常用命令:
    • docker network ls
    • docker network create <name>
    • docker network inspect <name>

原文链接:Docker basics - connecting containers(翻译:adolphlwq)

原文发布时间为:2017-07-11

本文作者:adolphlwq

本文来自云栖社区合作伙伴Dockerone.io,了解相关信息可以关注Dockerone.io。

原文标题:Docker基础:连接容器

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
17天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
157 77
|
25天前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
4天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
30 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
9天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
30 3
实战~如何组织一个多容器项目docker-compose
|
4天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
18 4
|
19天前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
60 3
|
25天前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
59 3
|
25天前
|
存储 安全 数据安全/隐私保护
Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。
在数字化时代,Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。本文探讨了 Docker 应用的备份与恢复策略,涵盖备份的重要性、内容、方法及常见工具,制定备份策略,恢复流程及注意事项,并通过案例分析和未来趋势展望,强调备份与恢复在保障应用安全中的重要性。
31 2
|
25天前
|
存储 安全 数据中心
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具。本文探讨了 Docker 如何通过 Namespace 和 Cgroups 实现 CPU、内存、网络和存储资源的隔离,提高系统安全性和资源利用率,以及面临的挑战和应对策略。
43 1
|
25天前
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
66 7