Python 把含有 TZ(UTC时间)的字符串 str 转换为 datetime 日期类型
今天在用 Python 处理 AWS S3 存储的时候遇到个时间格式的问题,特别在此记录下:
获取 bucket 下的 object 最后修改时间、然后对所有的超过 30 天的进行删除操作,但是提取到的是2018-03-05T09:20:005Z这种字符串。
今天在用 Python 处理 AWS S3 存储的时候遇到个时间格式的问题,特别在此记录下:
获取 bucket 下的 object 最后修改时间、然后对所有的超过 30 天的进行删除操作,但是提取到的是2018-03-05T09:20:005Z这种字符串。
nginx 代理配置完之后, nginx 配置proxy_pass,需要注意转发的路径配置问题.
在 nginx 中配置 proxy_pass 时,当在后面的url加上了'/',相当于是绝对根路径,则 nginx 不会把 location 中匹配的路径部分代理走;如果没有'/',则会把匹配的路径部分也给代理走。
在 MySQL 的使用过程中,如果 root 用户密码丢失了,会造成很大的麻烦。但是,可以通过某种特殊的办法登陆到 root 用户下,然后设置新的密码。
下面记录下当忘记MySQL root 密码的解决办法:
Docker Windows 客户端需要开启 Hyper-V,安装过程会自动提示打开与否。
Windows
Windows 下推荐使用 Docker for Windows 客户端,不要使用 docker toolbox。当从官方仓库拖取镜像时速度比较感人,建议使用国内镜像加速。
安装依赖包
1 | sudo yum install -y yum-utils \ |
用下面的命令设置 稳定版的 源地址
1 | sudo yum-config-manager \ |
安装 docker-ce
1 | sudo yum install docker-ce |
开始使用
1 | sudo systemctl start docker |
系统需求:
若安装有旧版本则先卸载
1 | sudo apt-get remove docker docker-engine docker.io |
安装依赖
1 | sudo apt-get update |
1 | sudo apt-get install \ |
1 | sudo apt-get install \ |
添加 Docker 官方 GPG key
curl -fsSL https://download.docker.com/linux/$(. /etc/os-release; echo "$ID")/gpg | sudo apt-key add -
设置 源地址
1 | sudo add-apt-repository \ |
安装 Docker-ce
1 | sudo apt-get update |
enjoy it:
sudo docker run hello-world
Linux
Debian 系统使用 apt-get 默认安装版本比较旧,使用 docker-compose 管理 Docker容器时会报错客户端和服务器版本不一致。建议按以上官方安装说明安装新版 Docker。
Nginx 是一个 web 服务器。它类似于 Lighttpd,作为轻量级的 web server,可以替代重量级的 Apache/IIS。Nginx 专为性能优化而开发,是一个快速且能经受高负载考验的 web server。详情见 wiki 页面
1 | docker pull nginx |
默认标签为最新版,若需要其它版本指定标签即可 请从docker hub获取帮助
nginx-proxy 启动一个容器来运行 nginx 和 docker-gen。 在主机上的容器启动和停止时 docker-gen 会生成 nginx 反向代理配置并且重新加载 nginx。
1 | docker pull jwilder/nginx-proxy |
启动 nginx-proxy 容器:
1 | docker run -d -p 80:80 -v /var/run/docker.sock:/tmp/docker.sock:ro jwilder/nginx-proxy |
再启动一个需要被代理的容器,使用环境变量 VIRTUAL_HOST=domain.com
1 | docker run -e VIRTUAL_HOST=domain.com nginx |
被代理的容器必须 expose 被代理的端口,可以通过在 Dockerfile 里面使用 EXPOSE 指令或者在 docker run 时使用 --expose 参数。
在 DNS 上设置转发 foo.bar.com 到 nginx-proxy 的主机上,之后请求就会被自动路由到设置了相同 VIRTUAL_HOST 环境变量的容器上。
letsencrypt-nginx-proxy-companion 是一个轻量级的代理容器,配合 nginx-proxy实现自动创建和自动更新 Let’s Encrypt 证书。
1 | docker pull jrcs/letsencrypt-nginx-proxy-companion |
要将其与原始 nginx 代理容器一起使用,您必须从 nginx-proxy 容器声明3个可写卷:
1 | docker run -d -p 80:80 -p 443:443 \ |
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy 是必需的,否则 Let’s Encrypt 不知道使用哪个容器。
2. 启动 LetsEncrypt
1 | docker run -d \ |
再启动需要被代理和加密的容器,加上环境变量 VIRTUAL_HOST=domain.com 。
docker run -e "VIRTUAL_HOST=foo.bar.com" ...
要使其能自动创建和更新证书需设置环境变量 LETSENCRYPT_HOST LETSENCRYPT_EMAIL 即可。
Compose 是定义和运行多容器Docker应用程序的工具。 使用Compose,您可以使用YAML文件来配置应用程序的服务。 然后,使用单个命令创建并启动配置中的所有服务。 要详细了解Compose的所有功能,请参阅功能列表。
使用以下命令
1 | sudo curl -L https://github.com/docker/compose/releases/download/1.17.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose |
赋可执行权限
1 | sudo chmod +x /usr/local/bin/docker-compose |
以管理员身份运行 PowerShell
1 | Invoke-WebRequest "https://github.com/docker/compose/releases/download/$dockerComposeVersion/docker-compose-Windows-x86_64.exe" -UseBasicParsing -OutFile $Env:ProgramFiles\docker\docker-compose.exe |
首先 创建一个 docker-compose.yml 的文件,在当前目录运行 docker-compose up 。
1 | version: '3' |
Good Luck!
本文章将帮助您基于 Gitpages快速搭建 Hexo 博客。如果您在使用过程中遇到问题,请在 GitHub、Google Group 上提问。