【易客吧】_全网激活码总代_激活码商城

您现在的位置是:首页 > 热门资讯 > 正文

热门资讯

通过 Docker 简化 Jenkins 安装:Linux 系统中的分步指南 (通过docker入侵主机)

用户投稿2024-04-11热门资讯21

Jenkins 是一个流行的开源持续集成 (CI) 和持续交付 (CD) 工具。它可以帮助您自动化构建、测试和部署软件。传统上,在 Linux 系统上安装 Jenkins 涉及遵循一系列手动步骤。Docker 提供了一种更简单且可移植的方法,本文将引导您完成使用 Docker 在 Linux 系统上安装 Jenkins 的过程。

先决条件

具有 root 或 sudo 权限的 Linux 系统安装了 Docker

步骤 1:从 Docker Hub 拉取 Jenkins 镜像

docker pull jenkins/jenkins

步骤 2:创建并运行 Jenkins 容器

docker run -d --name my-jenkins -p 8080:8080 jenkins/jenkins
`-d` 表示在后台运行容器。`--name my-jenkins` 为容器指定了一个名称。

如何在Ubuntu上借助Docker管理Linux容器

虽说标准的硬件虚拟化技术(比如KVM、Xen或Hyper-V)擅长于在一个物理主机上运行多个操作系统的完全隔离的实例,但这种虚拟化技术在性能、资源和资源配置时间等方面存在各种各样的开销。 标准的机器虚拟化实际上可能没有必要,这取决于你的实际使用场合。 另外一种轻型虚拟化方法就是所谓的Linux容器(LXC),它提供了操作系统级别的虚拟化。 由于不存在运行虚拟机带来的开销,LXC让用户可以在轻型容器沙盒里面运行标准Linux操作系统的多个实例。 如果你搭建一个可复制的开发/测试环境,或者在安全沙盒里面部署应用程序,容器就派得上大用场。 Docker就是为了便于部署Linux容器而开发的这样一款开源工具。 Docker正迅速成为容器技术方面的一项事实上的标准,已经被诸如Ubuntu和红帽之类的各大Linux发行版所采用。 我在本教程中将展示如何在Ubuntu 14.04上,借助Docker管理Linux容器。 请注意:对Ubuntu的早期版本而言,操作步骤可能略有不同。 眼下,Ubuntu上可用的Docker程序包只支持64位系统。 想在32位机器上运行它,你就要利用源代码构建32位版本的Docker(详见这里)。 安装Docker借助apt-get命令,安装Docker是件轻而易举的事。 $ sudo apt-get install 为了允许非根用户也可以运行Docker,将你自己添加到docker群组。 下面这个命令会允许当前用户运行Docker,无需根用户权限。 $ sudo usermod -a -G docker $USER 退出,然后重新登录,以激活群组成员的变化。 下一步,编辑Docker配置文件,以便更新Docker二进制代码的位置。 $ sudo vi /etc/default/ DOCKER=/usr/bin/ 重启Docker服务。 $ sudo service restart 管理Docker容器如果你想启动Ubuntu操作系统的一个新的Docker容器,首先需要获取Ubuntu Docker映像文件。 下面这个命令会通过网络下载Docker映像文件。 $ docker pull ubuntu 你可以以一种交互模式来开启Ubuntu Docker,如下所示。 最后一个参数“/bin/bash”是一旦启动就将在容器里面执行的命令,这里是一个简单的bash外壳命令。 $ docker run -i -t ubuntu /bin/bash 上述命令会立即启动一个Ubuntu容器(这正是容器的魅力所在!),并为你提供容器里面的外壳提示符。 这时候,你应该能够访问沙盒环境里面的标准的Ubuntu操作系统了。 想退出Docker容器,在容器里面的提示符处键入“exit”。 你可以启动不同形式的容器。 比如,想启动Fedora容器,请执行下面这个命令:$ run -i -t fedora /bin/bash 如果本地没有Fedora Docker映像文件,该命令就会首先自动下载映像文件,然后启动Docker。 如果你想启动采用某个发行版版本的容器,也可以这么做。 比如说,想启动Ubuntu 13.04 Docker,请执行下面这个命令:$ run -i -t ubuntu:13.04 /bin/bash 容器网络Docker使用Linux网桥将容器彼此互联起来,并将它们连接到外部网络。 安装了Docker后,你应该会看到默认情况下自动组建的docker0 Linux网桥。 你创建的每个容器都将连接到docker0网桥接口。 自定义Linux网桥如果你想,也可以使用自定义Linux网桥将诸容器互联起来。 为此,你可以建立一个自定义网桥,并对它进行配置,如下所示。 你可以为该网桥分配一个单独的子网,并且从子网为Docker分配IP地址。 我会使用10.0.0.0/24作为Docker子网。 $ sudo apt-get install bridge-utils $ sudo brctl addbr br0 $ sudo ifconfig br0 10.0.0.1 netmask 255.255.255.0 想让Docker使用自定义网桥,将“-b=br0”添加到/etc/default/中的DOCKER_OPTS变量,然后重启Docker服务。 $ sudo service restart 至此,任何新的容器都会连接到br0,其IP地址会自动从10.0.0.0/24来分配。 其他定制还有另外几种方法可以定制Docker的默认网络设置,主要是通过改动/etc/default/中的DOCKER_OPTS变量来实现。 “-dns 8.8.8.8 -dns 8.8.4.4”:指定容器使用的DNS服务器。 “-icc=false”:让诸容器彼此隔离开来。 故障排查1. 运行命令时,你会遇到下面这个错误。 dial unix /var/run/: no such file or directory(没有此类文件或目录) 出现这个错误,可能是由于Docker守护程序没在运行。 检查Docker守护程序的状态,确保先启动它。 $ sudo service status $ sudo service start

Linux下配置Docker容器间网络连接的教程

Docker容器都是独立的,互相隔离的环境。然而,它们通常只有互相通信时才能发挥作用。

虽然有许多方法可以连接容器们,可是我将并不会试着去将其全部讨论在内。但是在这一系列的方法中,我们将看看那些常用的做法。

虽然看起来是很浅显,但是这对于与Docker成天打交道的朋友来说,理解这些技术及底层的设计理念就显得非常地重要了。

配置

在我们展示容器间如何被连接之前,我们需要先建立一对容器作为本次的例子。

首先,我们创建该容器并连接到它。

代码如下:

$ sudo docker run -itd --name=client_setup ubuntu /bin/bash

$ sudo docker attach client_setup

接下来,一旦有了容器内的shell程序,我们就可以运行以下命令:

代码如下:

$ apt-get install curl

如果你看不见shell命令提示符,点击键盘方向区的向上箭头。

当容器安装完毕,执行CTRL+P和CTRL+Q命令退出该容器。

紧接着我们停止并提交该容器。

代码如下:

$ sudo docker stop client_setup

$ sudo docker commit client_setup client_img

现在我们可以使用刚才创建的名为client_img的容器了。

第二个容器我们还是从之前的Ubuntu操作系统的安装上获得。但是这一次,我们将把它修改成一个运行了Apache HTTP的服务器容器。

首先,我们像之前一样建立并且连接到它:

代码如下:

$ sudo docker run -itd --name=server_setup ubuntu /bin/bash

$ sudo docker attach server_setup

然后,一旦我们可以用容器内的shell程序了,就可以能安装Apache的HTTP服务了。

代码如下:

$ apt-get install apache2

当容器安装完毕,执行CTRL+P和CTRL+Q命令退出该容器。

现在我们停止并提交容器:

代码如下:

$ sudo docker stop server_setup

$ sudo docker commit server_setup server_img

那么现在我们就有了两个镜像了,分别是 client_img 和 server_img。

当这些设置好后,我们就可以探索多种的容器间连接的可能性了。

Docker桥接Bridge

单个Docker容器是默认地与其他容器和外部网络隔离的。Docker提供了bridge接口,名为docker0,这其实是在Docker Engine安装时就建立好的。

它通过Docker的bridge接口可以让容器间以及容器和主机之间进行通信。

我们可以通过下面的命令来查看一个位于Docker宿主机上的Docker bridge:

代码如下:

$ ifconfig docker0

你可以看到类似如下的输出:

代码如下:

docker0 Link encap:Ethernet HWaddr 02:42:a2:dc:0f:a8

inet addr:172.17.0.1 Bcast:0.0.0.0 Mask:255.255.0.0

inet6 addr: fe80::42:a2ff:fedc:fa8/64 Scope:Link

UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1

RX packets:1477 errors:0 dropped:0 overruns:0 frame:0

TX packets:2436 errors:0 dropped:0 overruns:0 carrier:0

collisions:0 txqueuelen:0

RX bytes (83.9 KB) TX bytes (3.6 MB)

该bridge接口在本地一个单独的Docker宿主机上运行,并且它是我们本篇文章所提及的所有三种方法背后的连接机制。在下一章节中,我们将转向overlay接口,这种接口允许把网络容器部署在多个Docker宿主机上。

端口公开Exposing Ports

首先,让我们看下如何运行一个容器服务并且公开其80端口(HTTP)给其他容器。

为了这么做,我通过expose命令去运行该容器,这是告诉Docker在运行该容器的时候让其公开特定的端口。当然,被公开的端口是可以被其他容器访问的。

让我们运行server_img并且把该容器命名为server1,公开其80端口:

代码如下:

$ sudo docker run -itd --expose=80 --name=server1 server_img /bin/bash

接下来我们会按依次命名这些容器(server1,server2以及其他)。

然后,连接到容器:

代码如下:

$ sudo docker attach server1

重申一遍,如果你看不见shell命令提示符,可以使用方向键的向上箭头。

启动该容器内的Apache HTTP服务:

代码如下:

$ /etc/init.d/apache2 start

让我们来看下获得的IP地址:

代码如下:

$ ifconfig

eth0 Link encap:Ethernet HWaddr 02:42:ac:11:00:03

inet addr:172.17.0.3 Bcast:0.0.0.0 Mask:255.255.0.0

那么,这样我们就有了172.17.0.3这个IP地址。让我们试一下从一个客户端的容器里去看这些信息吧。

打开第二个终端。

启动名称为client1的容器:

代码如下:

$ sudo docker run -itd --name=client1 client_img /bin/bash

进容器里看一下:

代码如下:

$ sudo docker attach client1

如果你看不见shell命令提示符,可以使用方向键的向上箭头。

让我们来测试一下到server1的连通性:

代码如下:

$ curl 172.17.0.3

如果一切正常,你应该可以看见基于Apache HTTP服务的默认页面。这表明client1容器已经可以与server1容器的HTTP端口正确地建立连接了。

端口绑定Port Binding

如果我们希望我们的HTTP服务器公开在主机网络呢,包括主机上的应用及主机网络上的其他机器?在这个方案中,我们需要去将主机端口绑定bind至容器端口。

为了让基于Apache的HTTP服务器公开给主机所处的网络,我们需要将该容器的80端口绑定至宿主机上的8080端口。

我们可以按照以下命令来这么做:

代码如下:

$ sudo docker run -itd -p 8080:80 --name=server2 server_img /bin/bash

在这里需要注意的是-p 8080:80选项。

现在,进容器看下:

代码如下:

$ sudo docker attach server2

如果看不见shell的提示符,和之前一样,按方向区的向上箭头,紧接着我们启动该HTTP服务:

代码如下:

$ /etc/init.d/apache2 start

现在,我们可以从宿主系统去访问,同时应该能看见基于Apache HTTP服务的默认页面。

任何在你主机网络内的那些机器都可以访问由你的宿主机所发布出来的8080端口。

容器链接Linking Containers

Docker将另一种涉及到的连接各容器的方法称为链接linking。

当你将一个容器链接到另一个容器的时候,Docker将通过一些环境变量来关联这些容器之间的信息。

我们可以看一下。

首先,启动该服务器容器。

代码如下:

$ sudo docker run -itd --name=server3 server_img /bin/bash

接着通过以下命令一样去启动客户机容器并链接至服务器容器。

代码如下:

$ sudo docker run -itd --link server3 --name=client3 client_img /bin/bash

请注意我们这里用了--link server3 选项。

接着我们登录到客户机容器看一眼:

代码如下:

$ sudo docker attach client3

然后我们检查一下可用的环境变量:

代码如下:

$ env | grep SERVER3

SERVER3_PORT_80_TCP_PROTO=tcp

SERVER3_PORT=tcp://172.17.0.2:80

SERVER3_PORT_80_TCP_PORT=80

SERVER3_NAME=/client3/server3

SERVER3_PORT_80_TCP=tcp://172.17.0.2:80

SERVER3_PORT_80_TCP_ADDR=172.17.0.2

Docker同样也更新了客户端容器中的/etc/hosts 文件并且将server3作为一个本地主机指向了服务器容器。

为了展示该情况,让我们运行以下命令看一看:

代码如下:

$ curl server3

你应该可以再一次看见那个相同的默认HTML页面了。

通过 Docker 简化 Jenkins 安装:Linux 系统中的分步指南 (通过docker入侵主机) 第1张

总结

在这一系列的第一部分,我们介绍了Docker桥接bridge接口,它可以让我们连接同一台宿主机上的各容器。

我们也聊了聊以下三种连接方法:

1.通过端口公开exposure连接

2.将宿主机端口绑定bind至容器端口

3.通过链接link选项去连接两个容器

怎么在docker里面安装软件

下载最近版的dockerforosxinstaller。 运行安装程序,安装virtualbox和boot2docker管理工具。 运行应用程序文件夹下的boot2docker应用:或者手动初始化boot2docker,打开终端并运行:?123$boot2dockerinit$boot2dockerstart$exportdocker_host=tcp://$(boot2dockerip2>/dev/null):2375一旦你初始化化好了一个虚拟机,你就能用boot2dockerstop和boot2dockerstart来进行控制。 chasehong翻译于1年前0人顶顶翻译的不错哦!更新下载最新版的dockerforosxinstaller运行安装程序,更新virtualbox和boot2docker管理工具。 更新现有虚拟机,打开终端并运行:?123$boot2dockerstop$boot2dockerdownload$boot2dockerstart运行docker在终端上跑一个“helloworld”的示例来测试docker。 启动虚拟机然后运行:?1$dockerrunubuntuechohelloworld这样应该会下载ubuntu镜像并打印helloworld。 容器端口跳转最新版的boot2docker建立了一个仅有网络适配器的主机提供可以接入容器的端口。 如果你运行一个有公开端口的容器,?1$dockerrun--rm-i-t-p80:80nginx然后你应该能用ip地址接入nginx服务器:?1$boot2dockerip通常,这个ip地址为192.168.59.103,但是也可能被virtualbox启用的dhcp修改。

若对本页面资源感兴趣,请点击下方或右方图片,注册登录后

搜索本页相关的【资源名】【软件名】【功能词】或有关的关键词,即可找到您想要的资源

如有其他疑问,请咨询右下角【在线客服】,谢谢支持!

通过 Docker 简化 Jenkins 安装:Linux 系统中的分步指南 (通过docker入侵主机) 第2张

发表评论

评论列表

  • 这篇文章还没有收到评论,赶紧来抢沙发吧~
欢迎你第一次访问网站!