我是 Linode 的忠实用户,目前我在用的是 20$ 一个月的「Linode 2048」套餐,内存是 2G,硬盘是 48G 的 SSD。记得刚开始用 Linode 时 19.9$ 才 512M 内存,20G 普通硬盘,后来才各种升级配置和带宽流量,去年还取消了年付 9 折的优惠。自从 Linode 出了日本 Tokyo 机房我就迁过去了,一直到现在,访问速度还算不错。
中间我还用过一段时间 DigitalOcean 的小水滴(他们的 VPS 实例叫 Droplet,也就是小水滴)。选的最便宜的那一档,512M 内存,20G SSD,5$ 一个月。当时用的是旧金山机房,后面出了新加坡也迁过去了,速度都不是很快。
最近不少同学都打算搞个 VPS 自己玩,其实如果只用来搭个博客,装个 ss
,搬瓦工(Bandwagon)有一款年付只要 9.9$ 的 VPS
比较超值。这个套餐叫「5G PROMO V2」,有独立 IP,可以自己装系统,理所当然有 root 权限。基本配置如下:
一共有四个机房可选:
我弄了一个洛杉矶的来玩,ping 在 100~200 毫秒之间。
搬瓦工支持 PayPal 付款,支持月付,但年付显然更优惠。「5G PROMO V2」的购买链接是:https://bandwagonhost.com/ca rt.php?a=confproduct&i=0。还有其他套餐可选:https://bandwagonhost.com/cart.php。综合看来,9.9$ 的这款各方面更均衡一些。
本文后半部分是以我的需求为出发点写的关于搬瓦工 VPS 的配置指南,不一定适合所有人。
搬瓦工这个 VPS 默认装的是 CentOS 6 系统,CentOS 全称是 Community Enterprise Operating System,从名称就可以看出它是面向企业级的系统,以稳定性著称。而我一直在用功能更丰富、更易用的 Ubuntu 作为我的 VPS 系统,从这么多年实际情况来看,只要不瞎折腾,Ubuntu 的稳定性也很不错,而且相关资料比较丰富,遇到问题解决起来比较方便。所以我决定把系统换成 Ubuntu 14.04 LTS。
首先从搬瓦工的后台进入 KiwiVM 控制面板,选择左侧的「Main Control」将 VPS 关机;再进入「Install new OS」页面,选择「ubuntu-14.04-x86-minimal」进行安装。这个版本的 Ubuntu 相当于精简版,去掉了很多默认软件和服务,很适合搬瓦工这款 VPS,装完之后只占用了几十 M 的内存和几百 M 的硬盘。
点击安装新系统后,页面上会显示新系统的 root 密码以及 ssh 端口号。
用 root 帐号登录 VPS 后,首先要新建一个用户。一般我们会用自己的帐号进行各项操作,必要时再通过 sudo
临时提权,这样更安全。adduser
这个命令能以交互界面创建新账号:
adduser jerry
设定密码、回答完相关问题之后,名为 jerry
的帐号就建好了。把它加到 sudo 权限组:
usermod -a -G sudo jerry
这时候可以通过 su jerry
切换到新帐号下工作。但这个精简版的 Ubuntu 居然没有 sudo 命令,su root
回到
root 账户下装一个:
apt-get update
apt-get upgrade
apt-get install sudo
有了 sudo,之后基本很少会用到 root 账户了,建议把搬瓦工生成的 root 默认密码改掉,免得时间一长忘记了。后续所有操作都在
jerry
帐号下进行。
拿到国外的 VPS 之后,一般都需要改下时区。使用这行命令就可以了:
sudo dpkg-reconfigure tzdata
拥有公网 IP 的 VPS 不可避免被人扫描和尝试登录。我在 Linode VPS 上装了 fail2ban 用来封掉不断尝试登录的 IP,每天能封掉几十个。要提高 VPS 帐号安全,最好只允许通过 SSH Key 登录。
首先,在需要登录 VPS 的电脑上查看 key 文件:
cd ~/.ssh/
如果这里已经有了 id_rsa
和 id_rsa.pub
文件,说明之前生成过,否则就要通过 ssh-keygen
命令生成一个新的:
cd ~/.ssh/
ssh-keygen -t rsa -C "quguangyu@gmail.com"
然后,复制 id_rsa.pub
文件的内容到剪切板。注意复制的时候不要出现换行,可以粘贴到文本编辑器检查下。在 Mac 下可以使用
pbcopy 这个命令来复制,避免出错:
pbcopy < id_rsa.pub
接着,登录 VPS,打开 authorized_keys
文件(没有就新建):
cd ~/.ssh/
vim authorized_keys
把复制的内容粘贴进去就可以了。现在不输入密码就可以登录,再禁用 VPS 的密码登录和 root 帐号登录:
sudo vim /etc/ssh/sshd_config
把下面两项都改成 no
:
PasswordAuthentication no
PermitRootLogin no
搬瓦工默认生成的 ssh 端口是一个很大的数字,不方便记。可以在 sshd_config
里把 Port 改回 22,或者通过 ssh
config 文件配置登录时使用的端口(具体方法看这里)。
完成这一切之后,记得重启 VPS 的 ssh 服务:
sudo service ssh restart
考虑到这个 VPS 内存有限,我并没有给它装 PHP,而是装了前端同学更熟悉的 NodeJS;数据库还是用的 MySQL;Web Server 则是 Nginx。
在 Ubuntu 下默认 apt-get 装的 NodeJS 是一个非常老的版本,我们需要用官网提供的脚本来装新版,下面就是全部命令:
sudo apt-get install apt-transport-https curl
curl -sL https://deb.nodesource.com/setup_4.x | sudo -E bash -
sudo apt-get install -y nodejs
目前我还在用 Node.js V4.x.x LTS,如果要安装最新版请参考官网文档。
通过 apt-get,可以很方便的安装 MySQL:
sudo apt-get install mysql-server
安装过程中需要设置数据库 root 密码。装完之后,通过下面命令来启动它:
sudo /etc/init.d/mysql start
在我的 VPS 上 MySQL 装完没办法正常启动,报了一个错误:
/etc/init.d/mysql: line 86: logger: command not found
重装 bsdutils
后一切正常:
sudo apt-get --reinstall install bsdutils
启动 MySQL 服务后,通过下列命令增强安全:
sudo mysql_secure_installation
由于我没装 PHP,没办法用 phpMyAdmin。Mac 下推荐用 Sequel Pro 这个免费好用的软件,通过 ssh 协议远程管理数据库。其他系统下也有类似的软件。
本文关于 Nginx 的安装和配置不再更新,请查看最新版:本博客 Nginx 配置之完整篇。
在 Ubuntu 下当然也可以通过 apt-get 安装 Nginx,但我并没这么做。因为我需要它支持 SPDY 协议,只能从源码安装。
首先,去 Nginx 和 OpenSSL 官网下载各自最新的源码包并解压:
cd ~/tmp/
wget http://nginx.org/download/nginx-1.8.0.tar.gz
wget https://www.openssl.org/source/openssl-1.0.2a.tar.gz
tar -xzf nginx-1.8.0.tar.gz
tar -xzf openssl-1.0.2a.tar.gz
安装依赖库,主要是 pcre 和 zlib 这两个:
sudo apt-get install libpcre3 libpcre3-dev zlib1g-dev
然后就可以编译和安装了。这里我指定了 openssl 的位置,并且指定要编译 spdy 和 ssl 这两个模块:
cd nginx-1.8.0
./configure --with-openssl=/home/jerry/tmp/openssl-1.0.2a/ --with-http_spdy_module --with-http_ssl_module
make
sudo make install
自己编译的 Nginx 没办法方便的启动。还要新建一个 nginx 启动脚本:
sudo vim /etc/init.d/nginx
输入以下内容:
#! /bin/sh
### BEGIN INIT INFO
# Provides: nginx
# Required-Start: $all
# Required-Stop: $all
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: starts the nginx web server
# Description: starts nginx using start-stop-daemon
### END INIT INFO
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
DAEMON=/usr/local/nginx/sbin/nginx
NAME=nginx
DESC=nginx
test -x $DAEMON || exit 0
# Include nginx defaults if available
if [ -f /etc/default/nginx ] ; then
. /etc/default/nginx
fi
set -e
. /lib/lsb/init-functions
case "$1" in
start)
echo -n "Starting $DESC: "
start-stop-daemon --start --quiet --pidfile /usr/local/nginx/logs/$NAME.pid \
--exec $DAEMON -- $DAEMON_OPTS || true
echo "$NAME."
;;
stop)
echo -n "Stopping $DESC: "
start-stop-daemon --stop --quiet --pidfile /usr/local/nginx/logs/$NAME.pid \
--exec $DAEMON || true
echo "$NAME."
;;
restart|force-reload)
echo -n "Restarting $DESC: "
start-stop-daemon --stop --quiet --pidfile \
/usr/local/nginx/logs/$NAME.pid --exec $DAEMON || true
sleep 1
start-stop-daemon --start --quiet --pidfile \
/usr/local/nginx/logs/$NAME.pid --exec $DAEMON -- $DAEMON_OPTS || true
echo "$NAME."
;;
reload)
echo -n "Reloading $DESC configuration: "
start-stop-daemon --stop --signal HUP --quiet --pidfile /usr/local/nginx/logs/$NAME.pid \
--exec $DAEMON || true
echo "$NAME."
;;
status)
status_of_proc -p /usr/local/nginx/logs/$NAME.pid "$DAEMON" nginx && exit 0 || exit $?
;;
*)
N=/etc/init.d/$NAME
echo "Usage: $N {start|stop|restart|reload|force-reload|status}" >&2
exit 1
;;
esac
exit 0
增加执行权限:
sudo chmod a+x /etc/init.d/nginx
搞定!现在启动 Nginx 只需要:
sudo /etc/init.d/nginx start
如果需要开机自动启动 Nginx,可以使用下面命令:
sudo update-rc.d -f nginx defaults
至此,本文就告一段落了。总之,VPS 自由度还是很大的,怎么折腾都可以,搬瓦工这个一年只需 9.9$ 的廉价 VPS 非常适合用来练手。
京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。
日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。
据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。
今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。
日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。
近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。
据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。
9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...
9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。
据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。
特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。
据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。
近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。
据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。
9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。
《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。
近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。
社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”
2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。
罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。