风火家人开发记要

技术总结精华贴

Category: 服务器

GoLang, 原创, 服务器, , ,

微信公众号消息回复Go语言实现

做此接口主要因为自己的网站都使用了go语言重写,而不想因为一个自动回复功能而需要保留php服务。 加密解密的源码已经放置到 GitHub上,请自行获取 https://github.com/chenxue4076/go-wechat-encryption go mod 导入方式 微信自动回复的api接口 核心代码如下 接口文件 wechat.go 就是url地址路由到的地址 repositories 目录里的处理函数如下: 附件:wechat配置参数 贴出的代码帮助参考使用,另外 https://github.com/chenxue4076/go-wechat-encryption 中的 demo也可以验证 加密解密的正确性 (748)

查看全文
原创, 服务器, , ,

使用docker的那些坑

依然是拿建网站来说明docker搭建mysql,php,nginx。使用PHP搭建起来的网站,自然 nginx要依赖php, php要依赖mysql,先看下所需容器 1.首先docker一个mysql,我使用的是mysql8.0,获取就不说了,这里直接docker –name 是为新容器起的名字, -p 本地端口:容器端口  -v 本地路径:容器路径, -v可设置很多路径映射,配置信息,日志信息,数据库存放路径,等等,记得还要同步本地时间哦,不然东八区的总差8小时, -e 环境变量,这个ROOT password 可以让我们避免首次登陆时去log查询初始密码的麻烦。 如果发现docker启动不起来,可以使用下面命令查看原因。 因为上面命令是我反复测试得到的命令,每次删除container后都可以直接使用则个命令启动,也不用担心重新配置信息或者数据丢失。出来下面的目录设置配置外,其他几个自定义目录都可以留空 通过下面的命令进入到 mysql8的容器中,使用上面的初始密码登录,需要提醒的是mysql8授权用户的时候,需要先创建相关用户,在赋予权限,不可一次执行。 安装mysql8还可以通过 docker-compose文件,配置如下 docker-compose.yml 现在我已经能正常使用数据库了,接下来是docker php-fpm。使用下面的命令创建php-fpm的容器,拉取php的fpm的最新版就行了 /data/www是我部署的网站,里面含有好几个站点,这里直接全部映射过去,php/extensions的相关扩展需要在启动docker后,进入docker中安装,比如下面是进入php的docker中安装pdo_mysql的扩展命令,最好在进入安装前,先打开php.ini中相应的扩展,如果不打开,创建后会在一个子目录下创建一个相应配置文件,并设置为开启,虽然结果都一样,但最好还是能统一在php.ini中配置。 这个docker命令中 我们使用 –link mysql8:mysql来把 mysql的网络段和php的网络段打通,我们可以进入php的docker中查看 /etc/hosts 里面会帮我们绑定mysql的IP,这样php就能够正常访问到mysql的网络中,以便访问数据库。 这里面的坑就是很多时候我们访问访问php地址的时候都是找不到文件,这个时候就需要你确保是否将网站路径映射到php docker中的正确位置了, 可以看到我使用了两次 -v /data/www的映射,这是因为才安装好的php docker 默认访问网站根目录是/etc/nginx/html, 我/data/www/中有html文件夹,所以我只绑定了前面, 而 -v /data/www:/data/www 则是因为我自定义了其他站点配置信息里面的目录都使用的/data/www/zizhandian的方式。 现在我们已经配置了几个php站点,需要使用nginx开启这些站点了,这里我们需要 –link下 php-fpm 这样就能让nginx正常访问到 php docker的网络段。 经过上面几条命令 我们已经能够正常访问php的站点了,php也能正常访问数据库了。 现在出现了另外一个问题,我有些服务是在 宿主机上开启的,那docker 容器怎么正常和宿主机通信呢? 当我查找这方面资料时,都是一些配置 iptable 防火墙策略,或者别名lo网络,真的有那么麻烦吗,我也被折腾了好几天,其实很简单。 docker 容器里面定义的网络段首个地址就是主机IP。这个我之所以被折腾很久,就是因为所谓的内网地址作怪。 我当前这台服务器内外IP是 172.17.1.4,我们分别进入 docker php-fpm 和 nginx80中查看hosts就会发现他们里面也绑定了,172.17.1.2 mysql,172.17.1.3 php-fpm, 172.17.1.4 nginx80 怎么回事呢,如果我们连主机内网IP 172.17.1.4却连到了nginx80上, 这里我们必须理解在 docker中的网络段他们都是相互独立的,当我们使用–link后 他们之间会通过host 绑定并且会在同一个网段呢, 那么我们的宿主机在docker里就是 172.17.1.1 这个初始IP,所以如果想连主机的IP,需要配置docker网络段的其实IP,不是127.0.0.1 也不是内网地址172.17.1.4。 这次docker学习的心得差不多就这些了。 另外一篇关于使用 Dockerfile 生成 PHP:FPM镜像的,并安装其他扩展的:使用php:fpm制作docker镜像并添加扩展redis,pdo_mysql等 (132)

查看全文
原创, 服务器

nginx服务器upstream timed out (110: Connection timed out)以及recv() failed (104: Connection reset by peer)解决方法

upstream timed out (110: Connection timed out) while reading response header from upstream 修改 nginx.conf 或者自定义的 如 vhost/blog.windigniter.com.conf   location / { root /data/www/blog.windigniter.com; index index.php index.html index.htm; if (!-e $request_filename){ rewrite ^(.+)$ /index.php last; } proxy_read_timeout 150; } location ~ \.php$ { root /data/www/blog.windigniter.com; fastcgi_read_timeout 150; fastcgi_pass windigniter; fastcgi_index index.php; include fastcgi_params; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param SCRIPT_NAME $fastcgi_script_name; } fastcgi_pass windigniter; 的配置是根据自己定义的 upstream来决定的,如下面2所示 2. recv() failed (104: Connection reset by peer) while reading response header from upstream 修改 nginx.conf upstream windigniter { server 127.0.0.1:9000 weight=1 max_fails=60 fail_timeout=30; } 经过以上 添加 添加粗体部分的内容就可以解决,110 Connection time out 和 104 Connection reset by peer 的问题了,上次在公司处理2的时候虽然已经重启了,但还是过了几分钟才生效,未查明原因。   (234)

查看全文
PHP, 原创, 服务器, ,

ceontos安装php7.2 提示cURL version 7.10.5 or later is required to compile php with cURL support

centos 安装 php7.2及以上版本的时候还是有几点需要注意的。 不要使用 php.net Download 提供的下载地址,而是使用 git上的下载地址,原因php.net下的里面存在一些bug,一些文件不全,导致无法安装mysqlnd扩展等。类似这种错误: ext/curl/multi.c:501: undefined reference to curl_pushheader_bynum 先安装一些依赖包 sudo yum install -y libxml2-devel sudo yum -y install libcurl-devel sudo yum install openssl openssl-devel sudo yum install bzip2 bzip2-devel sudo yum install freetype-devel sudo yum install libxslt-devel 在运行 ./configure –with-pdo-mysql=mysqlnd –with-mysqli=mysqlnd –enable-fpm –with-curl –with-fd –enable-mbstring 如果 centos7 php7动态编译出现mysqlnd: configure: error: Cannot find OpenSSL’s <evp.h> 错误,显然已经安装了openssl, openssl-devel,为什么还是提示这个错误,搜索了一下evp.h,这个文件也存在。GOOGLE 了一下,在stackoverflow,找到了答案,原来是 phpize 生成的configure脚本有问题。 解决方法: export PHP_OPENSSL_DIR=yes ./configure -with-openssl-dir=/usr/include/openssl –with-pdo-mysql=mysqlnd –with-mysqli=mysqlnd –enable-fpm –with-curl –with-fd –enable-mbstring 以上参数可根据实际情况先不带,后面需要在增加相关扩展。 Ubuntu先编译提示 evp.h的请参考 解决Ubuntu下php 7.0.6 生成 openssl.so报错,configure: error: Cannot find OpenSSLs evp.h。   (621)

查看全文