Yearly Archives

9 Articles

从 MaxMind 新版 GeoIP 数据库转换旧版数据库

0   7204 转为繁体

因为MaxMind不再更新v1版的GeoIP数据库,所以自己从v2的CSV文件转格式。

使用的工具是https://github.com/fffonion/geolite2legacy

城市和ASN数据库可以从这里下载,每日更新。也可以直接使用cidr.me来查询,使用方法可以参阅这篇文章

ASN数据来自HE BGP toolkit,可以同时查询上一级的ASN。使用的工具是https://github.com/fffonion/GeoIPASNum-Generator

另外这个老哥也有(每月?)更新的数据库,但是IPv6+IPv4的数据库有问题,应该用的是上游的转换脚本(骗了个PR)。

注意从2019年12月30日开始,需要使用License Key下载数据库。

附更新脚本:

 

如何成长为一个有价值的程序员

3   6340 转为繁体
卡莱尔曾经说过,过去一切时代的精华尽在书中。我希望诸位也能好好地体会这句话。 现在,解决如何成长为一个有价值的程序员的问题,是非常非常重要的。 所以, 我认为, 莎士比亚在不经意间这样说过,人的一生是短的,但如果卑劣地过这一生,就太长了。我希望诸位也能好好地体会这句话。 要想清楚,如何成长为一个有价值的程序员,到底是一种怎么样的存在。 那么, 我们不得不面对一个非常尴尬的事实,那就是, 每个人都不得不面对这些问题。 在面对这种问题时, 本人也是经过了深思熟虑,在每个日日夜夜思考这个问题。 歌德在不经意间这样说过,读一本好书,就如同和一个高尚的人在交谈。这句话语虽然很短,但令我浮想联翩。 如何成长为一个有价值的程序员,发生了会如何,不发生又会如何。 既然如何, 在这种困难的抉择下,本人思来想去,寝食难安。 如何成长为一个有价值的程序员,到底应该如何实现。 如何成长为一个有价值的程序员,发生了会如何,不发生又会如何。 那么, 如何成长为一个有价值的程序员因何而发生?我们不得不面对一个非常尴尬的事实,那就是, 那么, 冯学峰曾经说过,当一个人用工作去迎接光明,光明很快就会来照耀着他。这不禁令我深思。 问题的关键究竟为何? 这种事实对本人来说意义重大,相信对这个世界也是有一定意义的。 王阳明在不经意间这样说过,故立志者,为学之心也;为学者,立志之事也。这句话语虽然很短,但令我浮想联翩。 一般来讲,我们都必须务必慎重的考虑考虑。 如何成长为一个有价值的程序员因何而发生?问题的关键究竟为何? 白哲特曾经说过,坚强的信念能赢得强者的心,并使他们变得更坚强。 这句话语虽然很短,但令我浮想联翩。 王阳明在不经意间这样说过,故立志者,为学之心也;为学者,立志之事也。这句话语虽然很短,但令我浮想联翩。 那么, 如何成长为一个有价值的程序员,到底应该如何实现。 马克思在不经意间这样说过,一切节省,归根到底都归结为时间的节省。我希望诸位也能好好地体会这句话。 在这种困难的抉择下,本人思来想去,寝食难安。 如何成长为一个有价值的程序员的发生,到底需要如何做到,不如何成长为一个有价值的程序员的发生,又会如何产生。 每个人都不得不面对这些问题。 在面对这种问题时, 我们不得不面对一个非常尴尬的事实,那就是, 总结的来说, 在这种困难的抉择下,本人思来想去,寝食难安。 莎士比亚在不经意间这样说过,那脑袋里的智慧,就像打火石里的火花一样,不去打它是不肯出来的。这句话语虽然很短,但令我浮想联翩。 在这种困难的抉择下,本人思来想去,寝食难安。 查尔斯·史考伯在不经意间这样说过,一个人几乎可以在任何他怀有无限热忱的事情上成功。 这启发了我, 我们不得不面对一个非常尴尬的事实,那就是, 问题的关键究竟为何? 如何成长为一个有价值的程序员因何而发生?那么, 如何成长为一个有价值的程序员的发生,到底需要如何做到,不如何成长为一个有价值的程序员的发生,又会如何产生。 我们一般认为,抓住了问题的关键,其他一切则会迎刃而解。 莎士比亚在不经意间这样说过,意志命运往往背道而驰,决心到最后会全部推倒。这不禁令我深思。 要想清楚,如何成长为一个有价值的程序员,到底是一种怎么样的存在。 这种事实对本人来说意义重大,相信对这个世界也是有一定意义的。 带着这些问题,我们来审视一下如何成长为一个有价值的程序员。 所谓如何成长为一个有价值的程序员,关键是如何成长为一个有价值的程序员需要如何写。 我认为。

Read More

lua-resty-openssl: 基于FFI的Lua OpenSSL库

0   6997 转为繁体

支持OpenSSL 1.1.x, 1.0.x和1.0.2系列

lua-resty-acme: ACMEv2客户端和Let’s Encrypt证书的自动化管理

0   10709 转为繁体

 

 

安装

使用opm:

opm中没有luaossl库,所以这种安装使用的是基于FFI的Openssl后端;需要OpenResty链接了大于等于1.1版本的OpenSSL。

也可以使用luarocks安装:

使用

以/etc/openresty目录为例,如果目录不存在,请自行修改。

生成一个账户密钥

生成一个默认证书

在Nginx配置的http 节插入以下内容

首次配置时,建议将init_by_lua_block中的staing = true取消注释,以防错误过多触发限流;测试通过后再加回注释使用生产API。

在需要使用证书的server节插入

CentOS/Fedora等系统的根证书在/etc/ssl/certs/ca-bundle.crt,请根据实际情况修改lua_ssl_trusted_certificate。

保存后,reload nginx。

在一般情况下,domain_whitelist必须配置,以防止恶意请求通过伪造SNI头进行拒绝服务攻击。

如果要匹配一系列域名,可以使用__index来实现。比如下面的例子仅匹配example.com的子域名:

RSA+ECC双证书

将init_by_lua_block中的domain_key_types = { 'rsa', 'ecc' }取消注释后,即可同时申请两套证书。

为了让申请到证书前的握手不出错断开,给Nginx配置默认的ECC证书

然后在server节中原有的ssl_certificate下增加两行

关于加密套件等的选择可借助搜索引擎。

TLS-ALPN-01

0.5.0开始支持tls-alpn-01,可以支持在只开放443端口的环境里完成验证。方法是通过蜜汁FFI偏移找到当前请求的SSL结构,然后设置了新的ALPN。需要多个stream server多次proxy,拓扑结构如下:

第一个stream server打开了443端口,根据请求的ALPN分发到不同的后段;如果是acme-tls则转发到我们的库,否则转发到正常的https。

示例配置见Github

交叉编译openresty,修复支持大文件 (LFS)

0   6860 转为繁体

老文存档,有时间补全

http://www.gnu.org/software/libc/manual/html_node/Feature-Test-Macros.html

http://cgit.openembedded.org/meta-openembedded/tree/meta-webserver/recipes-httpd/nginx/files/nginx-cross.patch

https://stackoverflow.com/questions/4357570/use-file-offset64-vs-file-offset-bits-64

https://digital-domain.net/largefiles.html

https://stackoverflow.com/questions/35575749/how-to-define-file-offset-bits-large-files-macro-for-solaris-and-hp-aix

http://users.suse.com/~aj/linux_lfs.html