[转]使用Google Cloud + cloudflare永久免费运行一个网站

时间:2023-03-09 22:01:39
[转]使用Google Cloud + cloudflare永久免费运行一个网站

原文出处:https://www.jianshu.com/p/dc4c9996f4b9

除却域名的年费,我的博客站点是运行在云服务器上,如果没有意外,维护的费用应该是零。

云主机

云服务器我使用的是Google Cloud,谷歌云应该是目前唯一一个承诺提供永远免费 Always Free选项的云服务器提供商,其它云服务商应该只提供12个月免费使用选项给新用户

当然,谷歌云提供的永远免费选项仅能是使用一个性能超弱的实例:

  • 处于美国的机房
  • 单个共享的CPU核心
  • 600M的内存
  • 30G的存储

性能可能还比不上一个树莓派,但也已经足够让我用来跑一个网站。

环境

操作系统我为方便使用了:Ubuntu 18.04 LTS

数据库

数据库因故使用 MySql 8.0,但这直接在apt-get install mysql-server之后报错,看/var/log/mysql/error.log,显示:

--12T17::.393408Z  [System] [MY-] [Server] /usr/sbin/mysqld (mysqld 8.0.) initializing of server has completed
--12T17::.130992Z [System] [MY-] [Server] /usr/sbin/mysqld (mysqld 8.0.) starting as process
--12T17::.782754Z [ERROR] [MY-] [InnoDB] InnoDB: mmap( bytes) failed; errno
--12T17::.782817Z [ERROR] [MY-] [InnoDB] InnoDB: Cannot allocate memory for the buffer pool
--12T17::.782832Z [ERROR] [MY-] [InnoDB] InnoDB: Plugin initialization aborted with error Generic error.
--12T17::.782886Z [ERROR] [MY-] [Server] Failed to initialize DD Storage Engine
--12T17::.784009Z [ERROR] [MY-] [Server] Data Dictionary initialization failed.
--12T17::.784055Z [ERROR] [MY-] [Server] Aborting
--12T17::.789921Z [System] [MY-] [Server] /usr/sbin/mysqld: Shutdown complete (mysqld 8.0.) MySQL Community Server - GPL.
--12T17::.388162Z [System] [MY-] [Server] /usr/sbin/mysqld (mysqld 8.0.) starting as process
--12T17::.253414Z [ERROR] [MY-] [InnoDB] InnoDB: mmap( bytes) failed; errno
--12T17::.253518Z [ERROR] [MY-] [InnoDB] InnoDB: Cannot allocate memory for the buffer pool
--12T17::.253535Z [ERROR] [MY-] [InnoDB] InnoDB: Plugin initialization aborted with error Generic error.
--12T17::.253564Z [ERROR] [MY-] [Server] Failed to initialize DD Storage Engine
--12T17::.255109Z [ERROR] [MY-] [Server] Data Dictionary initialization failed.
--12T17::.255993Z [ERROR] [MY-] [Server] Aborting
--12T17::.320087Z [System] [MY-] [Server] /usr/sbin/mysqld: Shutdown complete (mysqld 8.0.) MySQL Community Server - GPL.

直接内存不足,mysqld无法启动。

只好修改/etc/mysql/mysql.conf.d/mysqld.cnf文件,在结尾增加:

performance_schema = off

一行,禁用performance_schema节省内存占用,mysql才得以正常启动。

nginx

当然,也还需要nginx,直接 apt-get install nginx即可。

应用

整个网站应用我是使用go编写,并且使用gorazoresc等工具将用到的模板、静态资源文件等到打包进可执行文件中。

整个程序运行时占用不到20M内存,还有百余兆空余内存:

$ cat /proc//status 

Name:   goblog
Umask:
State: S (sleeping)
Tgid:
Ngid:
Pid:
PPid:
TracerPid:
Uid:
Gid:
FDSize:
Groups:
NStgid:
NSpid:
NSpgid:
NSsid:
VmPeak: kB
VmSize: kB
VmLck: kB
VmPin: kB
VmHWM: kB
VmRSS: kB
RssAnon: kB
RssFile: kB
RssShmem: kB
VmData: kB
VmStk: kB
VmExe: kB
VmLib: kB
VmPTE: kB
VmSwap: kB $ free -h
total used free shared buff/cache available
Mem: 581M 352M 66M 900K 162M 135M
Swap: 0B 0B 0B

流量

谷歌云服务的免费实例运行时不收钱,但实例跑网站产生的流量可能是需要钱的,比方说,从中国、澳洲产生的访问流量则完全不免费。

怎么办?

在网站前面直接再套一个cloudflare的CDN,cloudflare有提供免费的CDN供个人站点使用!

cloudflare溯源去谷歌云的话,显然也不可能走中国、澳洲的流量。

总结

这样,我们就可以安安静静的近乎永久免费的跑一个网站了。

作者:玩家翁伟
链接:https://www.jianshu.com/p/dc4c9996f4b9
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。