docker保存自定义容器

上一篇介绍如何搭建lnmp环境
现在基本的环境已经部署好了,想把整个容器保存起来,像备份系统一样把容器备份起来。
把容器先保存成镜像,下次直接用保存起来的镜像来生成容器实例来运行,这样运行起来的容器是自己定义好的(自己备份时候的)样子。
将容器保存成镜像

debian是容器名称
mydebian 是保存的镜像名称

再查看镜像列表,就已经多了一个mydebian容器了

保存成镜像后,你就可以用这个镜像生成无数个容器了,而你的镜像不受任务影响。

还可将镜像保存成本地文件

将mydebian镜像保存成当前目录的mydebian.tar的文件

当然也可以从当前的文件中导入到镜像

将mydebian.tar文件导入成testdebian镜像

再查看镜像列表

testdebian已成功导入
当然你还可以把mydebian.tar拷到别的机器上导入。

我觉得开发人员使用docker可以像使用git的分支一样使用。需要一个环境的时候,生成一个docker容器,然后在容器上折腾,等折腾完了,不需要了再把容器删除了即可。等需要另外一个环境,再生成一个容器折腾。
对于我这种时常需要切换不同环境的开发者来说,docker可比虚拟机要好用多了。

docker上搭建LNMP环境

上一篇介绍在一个nginx容器上,如何管理docker容器
继续扩展,搭建一整套的环境,如LNMP环境( nginx + mysql + php)。
网上有介绍是通过容器连接的方式来实现,也就是一个nginx容器,一个mysql容器,一个php容器,然后通过配置来连接起来。形成一整套开发环境。
但对于一个开发环境来说,我并不建议这样子来做,因为开发环境本来就是要一个独立的环境,增加复杂性不说,独立性还不能保证。
我建议的方式是在一个容器里直接搭好所有的环境,然后启动容器的时候,一整套环境就启动起来。
上一篇已经有一个nginx容器上,可以登录到nginx容器中,在上面继续把mysql和php都装了。
但我选择重新下载一个干净有debian容器
使用命令

命令把镜像下载到本地

多了一个debian镜像(当然也可以选择其它的如ubuntu,centos之类的系统,看个人喜好)

用debian新建一个容器并启动起来

 

绑定了80端口和3306端口,3306是方便以后要访问mysql用

登录容器并执行bash

先装些必要的工作,比如

于是开始你的安装环境之旅吧

具体的安装过程网络上有很多,比如这里
How To Install Linux, Nginx, MySQL, PHP (LEMP Stack) on Debian 8

这样lnmp环境就安装好了。但当你再次启动debina容器的时候,这些服务是不会自己起来的,还是要你再登录进容器来手动启动这些服务。

一个解决方法是在根目录下新建个脚本 startup.sh,

填入以下内容

这个脚本的内容是启动mysql,nginx和php服务
保存妈出

给脚本执行权限

 

退出并关闭容器,

 

然后试下再启动

然后执行容器里的 startup.sh脚本来启动服务

服务都启动成功了,环境搭建完成。
下一篇想介绍一下如何保存并导入自定义好的镜像。

管理docker容器

上一篇介绍了安装和启动一个容器,并通过端口绑定成功访问到启动的nginx服务。
然而围住一想,还是什么也做不了:
1.nginx的根目录在哪,我们怎么更改它,怎么让它访问我们想它它访问的文件?
2.nginx的配置文件在哪。怎么加一个服务?或者怎么修改配置文件?

带着这些疑问往下说

一,绑定本地目录到容器目录
和绑定端口一样,子可以绑定本地的目录到容器中,这样可以在本地编辑文件,通过容器中的服务来访问。
首先把昨天创建的容器删除

重新生成并启动容器

通过-v命令,可以把本地的目录绑定到容器中,上面命令是把本地的 /web目录绑定到/var/www/html。
为什么要绑定到/var/www/html目录,好吧,后台看配置文件的时候会看到,当然可以绑定到别的目录,到时候改nginx的配置文件即可。

通过绑定后,就可以在你本地 /web下加任务你想加html文件,就可以通过浏览器访问了。就和编辑你本地的服务器文件一样。

二,登录到容器
运行起来的nginx容器,其它就是一个linux系统,当然也可以登录上去。
通过命令

就可以登录到正在运行的webserver容器了。命令行也已经切换到了容器里面。
-u 是指定登录的用户名
webserver 是当前运行的容器实例
bash 是登录上去运行的命令

登录上去后,这就是一个linux系统,可以查看系统信息

可以

还可以

不过安装软件前先apt-get update

当然也可以登录上去后运行任何命令,比如 ls 命令

这条命令的意思是登录到webserver容器上执行 ls 命令,执行完后就退出了

三,修改容器上的文件
1,直接在服务器上修改
既然已经登录到容器上了,就像使用linux系统一样,怎么改都可以。
但当你很高兴地打出vi /etc/nginx/nginx.conf的时候,会发现

啥?vi都没有,是的,vi也没有,这是一个相当干净的系统。
你只有自己装个vim再修改

安装完成后就可以用vi /etc/nginx/nginx.conf来修改配置文件了

2.在本地和容器间拷贝文件

docker的拷贝命令

这个命令和scp命令有点像

现在拷贝webserver容器中的/etc/nginx/nginx.conf文件 到当前目录

拷贝下来后,在你本地修改这个配置文件

修改完成后,再拷贝到容器中
拷贝当前目录下的nginx.conf文件到web容器的/etc/nginx/目录下

同理也可以用这种方式修改其它的文件和文件夹

好了,有时候光有了nginx还不行,还需要php,mysql等等。
下一篇打算写写如何打造真正的开发环境

开发人员打开docker的方式

以前写过一篇mac下利用docker搭建开发环境的文,但那时是用的boot2docker作为客户端搭建的,现在docker原生支持mac了,方便了许多。
首先,我是不建议直接在macOS系统中直接搭建各种开发环境的,一来会把软件装多了会把mac系统扰乱。会出现各种莫名其妙的环境问题。二来如果遇到环境要升级的问题也会很乱,三来macOS系统基本上也是一年升级一次,也会使各种搭好的环境出现问题。
一个解决办法是用VirtualBox来装虚拟机来解决,以前我也是这么干的,但虚拟机很重,想重新搭个环境要花比较长的时间,比如突然想下ubuntu16.10系统搭个开发环境。先下载系统,安装系统进虚拟机,然后再启动系统装环境。
现在有了docker一切问题都得到解决了欧耶。
就像船和集装箱一样。只要符合标准的集装箱,不用处理都可以直接往轮船上搬。而docker就是轮船这样的一种角色。一个装容器的容器,只是符合它的标准的容器都可以往上面装。
如果你想装个python环境,直接放个已经装好python环境的容器去运行起来,就是一个现成的python环境;
如果你想装一个nginx来运行web,直接放个已经装好nginx环境的容器。就是一个nginx环境了。
如果你现在用的是python2.7的环境,突然要用到python3,也可以直接装个python3的环境就是了,还避免了环境干扰。而且用完即删。
docker的发明最大的意义就是用于运维,但对于一个开发人员,也同样需要。

一.mac上装docker
到这里去下载安装即可
安装完成后运行,在右上角有一个小鲸鱼图标,docker就正常启动了,可以在终端里使用docker命令。

二.列出本地镜像
1.列出已存在本地的镜像

 

现在是空的,一个镜像也没有
假如我要装个nginx环境。怎么办?先去搜索一下吧

2.搜索镜像

 

搜出一大堆,下载第一个吧

3.下载镜像
$ docker pull nginx
等待完成,然后再用docker images命令列出本地镜像

 

nginx镜像已下载到本地

4.运行镜像,也就是用镜像来实例化一个容器并运行(可以拿面向对象中的类和实例来作比)

 

意思是:用nginx镜像,来运行一个容器,容器的名字叫webserver,-d 是后台运行,-p是绑定端口,在这里只绑定了80端口(即把本机的80端口和容器的80端口绑定,访问本机的80端口相当于访问容器的80端口)
成功生成容器并运行,查看一下运行的实例吧

5.查看运行实例

 

从左到右分别是容器id,所使用的镜像,运行时的命令,创建时间,状态,绑定的端口,名字
容器已经运行起来
在浏览器上输入http://localhost/,会出现nginx 欢迎页面

6.关闭容器

7.其它的一些常用命令

列出所有的容器(包括运行中的,和已经停止的)
docker ps -a

启动一个容器

 

删除容器

docker rm -f webserver (强制删除,如果容器正在运行,这条命令会先关闭容器,再删除之)

删除镜像(记住是镜像,不是容器)

 

这个是基础,下一篇打算写写可以更高效利用docker来开发

树莓派 自动发布天气信息到QQ空间/微博

转载至raspberry pi 自动发布天气信息到QQ空间/微博

说明:

天气信息来自于百度地图API,历史上的今天来自于网络API(见上).

准备工作:

安装python(没有的,自行下载安装)

安装requests:

安装python-rsa

安装qqlib

主要脚本:

备注:红色字体根据自己实际修改.

  main.py

  weibo.py

附录:

百度天气API返回JSON示例:

历史上的今天返回JSON示例:

 

树莓派 之 dnsmasq搭建DNS服务器

转载至树莓派 之 dnsmasq搭建DNS服务器

Dnsmasq是一款高性能的DNS缓存软件,可以使用它来搭建一个小型的DNS服务器。在使用时,由于dnsmasq可以将域名缓存下来,这样下次就不用再次请求上游的DNS服务器,使用时极大的加快了上网速度,从而提升了上网体验。如果你有树莓派在闲置,那就赶快利用起来吧,使用你手里的树莓派来搭建一个自己的DNS服务器吧。

配件:
树莓派 一片 即可

安装Dnsmasq

sudo apt-get install dnsmasq

安装DNSMASQ.png

配置Dnsmasq

Dnsmasq的配置文件为 /etc/dnsmasq.conf ,使用vim 打开配置文件

sudo vim /etc/dnsmasq.conf

去掉strict-order前面的#号
设置listen-address,配置如下:

listen-address=127.0.0.1,192.168.1.103

如果只加上127.0.0.1,表示只能为本机提供dns服务,如果需要为局域网的其他电脑提供dns服务,需要再加上树莓派在局域网内的IP地址。

修改缓存大小

cache-size=10000

保存dnsmasq.conf文件
修改resolv.conf文件,添加以下几行:

nameserver 127.0.0.1
nameserver 223.5.5.5
nameserver 114.114.114.114

第一行是自动生成的,表示查询DNS时首先从本地查找,找不到了才从下面的上游DNS服务器查找。

保存resolv.conf文件
重启dnsmasq

sudo service dnsmasq restart

查看服务状态

sudo service dnsmasq status

输出信息如下:

QQ截图20161002200916.png

OK,安装成功了!在其它电脑上就可以使用树莓派DNS缓存服务器了,明显可以看到解析域名的速度大大提高,基本上第一次解析花点时间,以后访问时的速度有了极大提高。

 

树莓派3开无线热点变身为智能无线网关(IPv4+IPv6)

转载这篇文章树莓派3开无线热点变身为智能无线网关(IPv4+IPv6),感谢作者

 

准备工作

整个过程分为两步,先开IPv4的热点access point,再共享IPv6的热点access point,热点都不是采用bridge方式进行的连接。

固定IP(IPv4)

后面的树莓派默认使用dhcpcd进行ip的配置,因此网上好多关于配置树莓派固定IP的方法都是有点问题(很早的时候是配置/etc/network/interfaces),我们现在配置dhcpcd的配置文件进行固定IP的配置,打开配置文件/etc/dhcpcd.conf

1

sudo vim /etc/dhcpcd.conf

里面内容不少,感兴趣可以查一下,这里直接拖到最下,根据自己的情况加入下面的内容

1
2
3
4

interface eth0
static ip_address=211.187.224.79/24
static routers=211.187.224.16
static domain_name_servers=114.114.114.114

其中ip_address后面接的是CIDR格式的ip地址,/24是指的netmask是255.255.255.0,地址根据自己的情况填一下即可。
重启就可以上网了。ping一下外网看一下是不是已经通了,IPv6是用ping6。

配置IPv4热点access point

这里使用的是NAT转发
先装依赖

1

sudo apt-get install dnsmasq hostapd

之所以使用dnsmasq是因为配置简单,而hostapd是必不可少的虚拟热点的程序,hostapd对ipv4和ipv6都支持。
配置的时候要给我们的wlan0一个固定的内网IP,再次编辑我们的dhcpcd.conf,在最后接上下面的内容

1
2

interface wlan0
static ip_address=10.0.0.1/24

继续配置dnsmasq,在/etc/dnsmasq.conf的最后加上下面一段(此文件内容很多,但都被注释掉了)

1
2

interface=wlan0
dhcp-range=10.0.0.2,10.0.0.5,255.255.255.0,12h

编辑/etc/hostapd/hostapd.conf文件(新文件),加上下面的内容

1
2
3
4
5
6
7
8
9
10

interface=wlan0
hw_mode=g
channel=10
auth_algs=1
wpa=2
wpa_key_mgmt=WPA-PSK
wpa_pairwise=CCMP
rsn_pairwise=CCMP
wpa_passphrase=密码
ssid=名称

把密码和名称替换成自己想设置的就可以了。接着修改/etc/sysctl.conf文件,找到下面一行去掉#

1

net.ipv4.ip_forward=1

继续,更新下iptables的规则:

1
2
3
4
5

sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
sudo iptables -A FORWARD -i eth0 -o wlan0 -m state –state RELATED,ESTABLISHED -j ACCEPT
sudo iptables -A FORWARD -i wlan0 -o eth0 -j ACCEPT

sudo sh -c “iptables-save > /etc/iptables.ipv4.nat”

最后一句的目的是将我们执行的三句iptable设置保存下来,以后能直接使用,我们保存到了/etc/iptables.ipv4.nat位置。编辑/etc/network/interfaces,最后加上下面这句话,每次开机都会配置好iptables的内容了

1

up iptables-restore < /etc/iptables.ipv4.nat

既然打开这个文件了,可以把上面的几句wlan的interface注释一下,反正这些话也没用了,即变成这样:

1
2
3
4
5
6
7

allow-hotplug wlan0
iface wlan0 inet manual
# wpa-conf /etc/wpa_supplicant/wpa_supplicant.conf

#allow-hotplug wlan1
#iface wlan1 inet manual
# wpa-conf /etc/wpa_supplicant/wpa_supplicant.conf

为了能够每次开机自动运行hostapd,我们还要修改/etc/rc.local文件,在exit 0 前加上下面这句话

1

hostapd -B /etc/hostapd/hostapd.conf & > /dev/null 2>&1

重启,就可以看到热点了。至此IPv4部分完成。

参考资料:

树莓派3内置WIFI无线路由器AP热点: https://item.congci.com/-/content/shu-mei-pai-3-neizhi-wifi-wuxian-luyouqi-ap-redian
这个文章还提到了桥接方式进行连接的方法: http://wangye.org/blog/archives/845/

配置IPv6热点access point

前面的配置方法网上一搜一大把,这里其实就是记录一下,真正花了我两天时间的是配置IPv6的无线热点。。类似IPv4的配置方法,这里主流配置有两种,一种是使用桥接把无线的IPv6流量转到有线的IPv6上,这种方法配置简单,但我用上后只能坚持几十秒,整个树莓派就再也不能上网,只能重启(非常怀疑学校里在配置了交换机,不让使用桥接),另一种就是我最后成功的使用radvd+npd6+DHCPv6+hostapd的这种NDP连接。
这里也写一下第一种方法,毕竟曾让我高兴了几十秒,本着记录为目的的话还是要记一下。两种方法只能选一种,强烈建议使用第二种方法

IPv6 桥接

编辑配置文件/etc/sysctl.conf,把下面一行的注释去掉

1

net.ipv6.conf.all.forwarding=1

用ifconfig看一下自己的ipv6的地址,注意Scope:Global的那个地址是你的IPv6外网地址,Scope:Link的那个地址应该是你的上级地址。我们这里只关注Global那一项,安装radvd

1
2
3
4
5
6
7
8
9
10
11
12

sudo apt-get …

树莓派raspbian安装samba共享

安装了owncloud后,各终端就可以同步了,pc,mac,android,ios都是对应客户端,但是没有电视客户端,比如服务器上的相片和下载的视频就不能在小米电视里看,于是就想到了用samba来实现共享,一来电视上可播放共享内容,各种设备音也方便文件管理。
想法是把owncloud中某些数据用来共享给电视使用,比如把音乐,视频,和相片共享。这样来实现手机上当天拍的照片和视频,在手机上同步一下就可以在电视上播放了,备份和共享两不误。
当然连接到局域网wifi下的所有设备都能看到共享,每个来到家玩的来只要连接了wifi,就能看到你共享的相片,怎么办呢?
一个办法是设置个用共享用户,另一个方法是通过连接的mac地址来区分。

一,安装samba

二,配置samba
养成好习惯,先把配置文件备份一下
sudo cp /etc/samba/smb.conf /etc/samba/smb.conf.bak

修改配置文件

在其最后添加以下命令:

保存退出

重启samba服务

这样共享目录就可访问了

mac下用finder的 前往 —> 连接服务器

输入smb://ip/share就可访问了(ip是树莓派地址)

还可以添加其它目录,配置/etc/samba/smb.conf文件,末尾添加

 

要添加共享用户:

重启samba就可以了

树莓派raspbian安装owncloud私有云

owncloud是一个开源的私有云系统,类似于国外的Google Drive、Dropbox、SkyDrive,和国内的百度云等网盘一样。在家庭搭建私有云来管理和分享家庭成员的各种照片,音乐,文档等各种文件,即保证速度又比百度云等网盘安全。
一,更新系统

二,安装LAMP套件

1.安装apache2

 

2.安装mysql

 

3.安装php和依赖

4.从 https://owncloud.org/install/ 下载最新的ownCloud Server,并解压到web根目录(/var/www/html)

6.OwnCloud在安装的过程中需要对一些目录有写的权限,为此,web服务器用户(www-data对于基于Debian的系统)必须要拥有apps、data、config目录的权限。运行以下命令完成:

7.打开浏览器,输入 http://IP/owncloud ,进入设置安装界面,根据提示安装填写新用户名,密码;数据库用户名,密码等,即可安装完成。(IP为树莓派的地址)

将系统挂载到usb硬盘

       系统装好在sd卡启动正常后,就可以将移动硬盘通过usb接口接入并挂载来用了。由于原来系统装在SD卡上,由于SD卡读写速度原因,导致系统有些卡。特别在读写系统文件的时候特别卡。我想将整个raspbian系统都转移到移动硬盘上。以便提高系统性能。
      首先准备一块移动硬盘,通过usb接入到树莓派上来(注意移动硬盘要单独供电),分好区后格式化。由于我的硬盘是从之前电脑来折下来的,原来装的ubuntutxxy,原本已经分好区了,也有好多数据在硬盘上,为了使数据不丢失,就不再重新分区了。

一,将系统从SD卡拷贝到硬盘上

1.把硬盘插入到树莓派,使用lsblk命令查看设备名:

这是我的硬盘信息,sda是硬盘,mmcblk0是sd卡,我的硬盘分成4个区,sad1作为boot目录,sda6作为根目录,sda7作为swap,sda5作为主数据存储。

2.创建boot文件系统和root文件系统:

3.把当前Raspbian系统从SD卡拷贝到USB设备

4.刷新SSH密

 

二,修改启动配置
1.编辑/mnt/target/boot/cmdline.txt和t/boot/cmdline.txt文件
原来的内容

把它修改成:

2.编辑/mnt/target/etc/fstab和/etc/fstab文件
原来的内容:

把它修改成:

3.卸载挂载的文件系统

三.重新启动

重新启动后,登录进系统,用df -h查看挂载情况

 

显示已成功挂载
再用free -h查看swap挂载情况

swap分区也已成功挂载

再用lsblk查看设备名

 

SD卡中的mmcblk0p1和mmcblk0p2分区已不再挂载了,这样整个文件系统都在硬盘中了

那么问题来了,能不能把SD卡拨出,只从硬盘启动呢,从理论上应该是可以的。
于是我就是树莓派关了,把SD卡拨出,只插了移动硬盘。
启动

让我感到悲伤的是系统没有启动,接入显示器想看看有什么启动信息,结果什么都没有,唯一的解释是没有找到引导盘。

关掉电源后,把SD卡重新插入再启动,这次可以启动成功了,目录挂载也都是正确的。我估计是硬盘没有重新分区格式化过,导致找不到引导盘,只能从SD卡引导,从移动硬盘启动。
暂是这样,以后想办法解决这个问题