实战申请Let’s Encrypt永久免费SSL证书过程教程及常见问题

Let’s Encrypt作为一个公共且免费SSL的项目逐渐被广大用户传播和使用,是由Mozilla、Cisco、Akamai、IdenTrust、EFF等组织人员发起,主要的目的也是为了推进网站从HTTP向HTTPS过度的进程,目前已经有越来越多的商家加入和赞助支持。
Let’s Encrypt免费SSL证书的出现,也会对传统提供付费SSL证书服务的商家有不小的打击。到目前为止,Let’s Encrypt获得IdenTrust交叉签名,这就是说可以应用且支持包括FireFox、Chrome在内的主流浏览器的兼容和支持,虽然目前是公测阶段,但是也有不少的用户在自有网站项目中正式使用起来。

虽然目前Let’s Encrypt免费SSL证书默认是90天有效期,但是我们也可以到期自动续约,不影响我们的尝试和使用。

第一、安装Let’s Encrypt前的准备工作

根据官方的要求,我们在VPS、服务器上部署Let’s Encrypt免费SSL证书之前,需要系统支持Python2.7以上版本以及支持GIT工具。这个需要根据我们不同的系统版本进行安装和升级,因为有些服务商提供的版本兼容是完善的,尤其是debian环境兼容性比CentOS好一些。在这篇文章中,橘子采用的是Ubuntu 16.10环境。

第二、快速获取Let’s Encrypt免费SSL证书

PS:在获取某个站点证书文件的时候,我们需要在安装PYTHON2.7以及GIT,更需要将域名解析到当前VPS主机IP中。

git clone https://github.com/letsencrypt/letsencrypt
cd letsencrypt
./letsencrypt-auto certonly --standalone --email OrangeJX@qq.com -d kidding.pub -d www.kidding.pub

然后执行上面的脚本,我们需要根据自己的实际站点情况将域名更换成自己需要部署的。


看到这个界面直接”A”就好,意思就是问你是否同意他们的协议。(PS:协议的地址是https://letsencrypt.org/documents/le-sa-v1.1.1-august-1-2016.pdf,)


这个提示的意思是问你他们是否可以给你推送一些邮件和通知。(我是同意的,毕竟证书都用了人家的了,适当的时候支持下人家还是很有必要的)


我在安装的时候出现了这个提示,仔细一看是提示我的443端口被占用了,申请这个证书是需要443端口的,所以我关闭了正在使用的443端口,重试,通过.


然后看到这个界面表示部署成功.配置好虚拟主机之后,重新启动lampp.


错误?哦,原来我忘记用管理员权限了.重新使用管理员权限执行命令,重启成功.

第三、Let’s Encrypt免费SSL证书获取与应用

在完成Let’s Encrypt证书的生成之后,我们会在”/etc/letsencrypt/live/kidding.pub/”域名目录下有4个文件就是生成的密钥证书文件。
cert.pem – Apache服务器端证书
chain.pem – Apache根证书和中继证书
fullchain.pem – Nginx所需要ssl_certificate文件
privkey.pem – 安全证书KEY文件
如果我们使用的lamp环境,那就需要用到cert.pem和privkey.pem两个证书文件,在部署lamp的时候需要用到.

ssl_certificate /etc/letsencrypt/live/kidding.pub/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/kidding.pub/privkey.pem;

比如我们在lamp环境中,只要将对应的ssl_certificate和ssl_certificate_key路径设置成我们生成的2个文件就可以,最好不要移动和复制文件,因为续期的时候直接续期生成的目录文件就可以,不需要再手工复制。

第四、解决Let’s Encrypt免费SSL证书有效期问题

我们从生成的文件中可以看到,Let’s Encrypt证书是有效期90天的,需要我们自己手工更新续期才可以。

./letsencrypt-auto certonly --renew-by-default --email OrangeJX@qq.com -d kidding.pub -d www.kidding.pub

这样我们在90天内再去执行一次就可以解决续期问题,这样又可以继续使用90天。如果我们怕忘记的话也可以制作成定时执行任务,比如每个月执行一次。

第五、关于Let’s Encrypt免费SSL证书总结

通过以上几个步骤的学习和应用,我们肯定学会了利用Let’s Encrypt免费生成和获取SSL证书文件,随着Let’s Encrypt的应用普及,SSL以后直接免费不需要购买,因为大部分主流浏览器都支持且有更多的主流商家的支持和赞助,HTTPS以后看来也是趋势。在Let’s Encrypt执行过程在中我们需要解决几个问题。

A – 域名DNS和解析问题。在配置Let’s Encrypt免费SSL证书的时候域名一定要解析到当前VPS服务器.
B – 安装Let’s Encrypt部署之前需要服务器支持PYTHON2.7以及GIT环境,要不无法部署。
C – Let’s Encrypt默认是90天免费,需要手工或者自动续期才可以继续使用。

文章转自<老左博客>

ubuntu创建和配置swap

digital ocean虚拟主机默认是没有开启swap功能的。对于最低配的512M内存的主机,一般需要一个512M或者1G的swap比较好,不然内存很可能不够用导致进程挂掉。
所以只好自己动手配置swap。
首先要创建一个swap格式的文件:

sudo dd if=/dev/zero of=/swapfile bs=1024 count=512k

dd命令是专门用来从一个文件复制并格式成另一个文件。这条命令的意思是从”/dev/zero”文件读出内容并存到/swapfile文件中,块大小为1024Byte,总共 512 K个块,也就是总共 512M。
然后设置并开启交换文件:

sudo mkswap /swapfile
sudo swapon /swapfile

最后设置开机自动装载swap文件:
编辑 /etc/fstab ,加入如下一行:

/swapfile none swap defaults 0 0

/etc/fstab 是存放文件系统信息的地方,系统启动的时候会自动从这里面读取并装载文件系统。其中前三个参数并别表示:
要装载的文件系统物理位置(就是我们上一步创建的那个swap文件),挂载点(对于swap设置为none就行了),文件格式(swap格式)

然后用free命令查看下内存使用情况,在物理内存下应该能看到swap的信息:

total used free shared buffers cached
Mem: 1027156 721928 305228 0 9840 267224
-/+ buffers/cache: 444864 582292
Swap: 524284 0 524284

或者用swapon -s直接查看swap信息:

Filename Type Size Used Priority
/swapfile file 524284 0 -1

服务器开启TCP BBR拥塞控制算法

听说TCP BBR在带宽上效果不错,所以决定在主服务器上启用试试。
tcp_bbr要在4.9.x内核及以上才有用,所以可能需要升级一下内核。

1.查看当前内核版本

uname -a

Linux a.sof618.com 4.4.0-59-generic #80-Ubuntu SMP Fri Jan 6 17:47:47 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux

2.版本不对,到kernel ubuntu找到最新版的4.9.x内核,然后下载、安装。

wget http://kernel.ubuntu.com/~kernel-ppa/mainline/v4.9.6/linux-headers-4.9.6-040906_4.9.6-040906.201701260330_all.deb

wget http://kernel.ubuntu.com/~kernel-ppa/mainline/v4.9.6/linux-headers-4.9.6-040906-generic_4.9.6-040906.201701260330_amd64.deb

wget http://kernel.ubuntu.com/~kernel-ppa/mainline/v4.9.6/linux-image-4.9.6-040906-generic_4.9.6-040906.201701260330_amd64.deb

dpkg -i linux-*

3.安装完成后重启,新的内核生效。

uname -a

Linux a.sof618.com 4.9.6-040906-generic #201701260330 SMP Thu Jan 26 08:32:10 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux

4.之后可以考虑删除其余内核

dpkg -l|grep linux-image

5.编辑sysctl.conf文件启用bbr,文件末尾添加以下两行

net.core.default_qdisc=fq
net.ipv4.tcp_congestion_control=bbr

6.重启或者立即生效配置。

sysctl -p

7.查看bbr是否已经启用。

sysctl net.ipv4.tcp_available_congestion_control
lsmod | grep bbr

转自《mjollnir

for和of的区别

for和of是英文中常用的两个介系词。
for这个介系词在英文中的基本含义是“为了”,即表示目的或原因,还可以引导一个间接宾语。如:
Isn’t that enough for you?
I have some free advice for you.
a room for rent.
Tom left for New York.
The train for New York has already arrived.
of这个介系词在英文里的基本含义是“的”,构成名词的所有格形式,用在两个名词之间,如:
The door of the room is open.
I know the mother of the boy.
The doors of the car are closed.
The problem of air pollution in cities is getting more and more serious.
转自《百度知道

php中序列化与反序列化

把复杂的数据类型压缩到一个字符串中
serialize() 把变量和它们的值编码成文本形式
unserialize() 恢复原先变量
eg:

$stooges = array(‘Moe’,’Larry’,’Curly’);
$new = serialize($stooges);
print_r($new);echo “<br />”;
print_r(unserialize($new));

结果:a:3:{i:0;s:3:”Moe”;i:1;s:5:”Larry”;i:2;s:5:”Curly”;}

Array ( [0] => Moe [1] => Larry [2] => Curly )

当把这些序列化的数据放在URL中在页面之间会传递时,需要对这些数据调用urlencode(),以确保在其中的URL元字符进行处理:

$shopping = array(‘Poppy seed bagel’ => 2,’Plain Bagel’ =>1,’Lox’ =>4);
echo ‘next‘;

margic_quotes_gpc和magic_quotes_runtime配置项的设置会影响传递到unserialize()中的数据。
如果magic_quotes_gpc项是启用的,那么在URL、POST变量以及cookies中传递的数据在反序列化之前必须用stripslashes()进行处理:

$new_cart = unserialize(stripslashes($cart)); //如果magic_quotes_gpc开启
$new_cart = unserialize($cart);

如果magic_quotes_runtime是启用的,那么在向文件中写入序列化的数据之前必须用addslashes()进行处理,而在读取它们之前则必须用stripslashes()进行处理:

$fp = fopen(‘/tmp/cart’,’w’);
fputs($fp,addslashes(serialize($a)));
fclose($fp);
//如果magic_quotes_runtime开启
$new_cat = unserialize(stripslashes(file_get_contents(‘/tmp/cart’)));
//如果magic_quotes_runtime关闭
$new_cat = unserialize(file_get_contents(‘/tmp/cart’));

在启用了magic_quotes_runtime的情况下,从数据库中读取序列化的数据也必须经过stripslashes()的处理,保存到数据库中的序列化数据必须要经过addslashes()的处理,以便能够适当地存储。

mysql_query(“insert into cart(id,data) values(1,'”.addslashes(serialize($cart)).”‘)”);
$rs = mysql_query(‘select data from cart where id=1’);
$ob = mysql_fetch_object($rs);
//如果magic_quotes_runtime开启
$new_cart = unserialize(stripslashes($ob->data));
//如果magic_quotes_runtime关闭
$new_cart = unserialize($ob->data);

当对一个对象进行反序列化操作时,PHP会自动地调用其__wakeUp()方法。这样就使得对象能够重新建立起序列化时未能保留的各种状态。例如:数据库连接等。

文章转自《CNBlogs