VPS+LNMP+WordPress搭建个人网站/博客

    分享 jwcyber 8年前 (2016-03-02) 1034469次浏览 258个评论

    恭喜你找到这里,自认为这篇建站教程还是不错的,毕竟也已经10W+了,看完后你应该能够搭建出一个网站来。
    下面的链接也是一篇不错的文章,推荐可以去那里看看。
    SEOIMO__VPS搭建LAMP安装WordPress建站及优化教程 (Vultr & 搬瓦工VPS亲测)

    写在前面

    很久之前就想拥有一个属于自己网站,和腾讯新浪等提供的公共空间不同,这是属于自己的地盘,是自己在互联网上的一亩三分地,可以想怎么玩就怎么玩(尽管服务器域名程序都是别人的)。

    想象中做出一个网站难度是很大的,实际操作后才知道现在网站建设的各个方面都已经非常成熟,即使什么都不会,搜搜教程,很快就能折腾出来一个网站。基本零基础的我花了一天时间就从零进行到能打开网页的程度,其中大部分时间还是在选择VPS和网站程序(WP or Z-blog)。

    有了这样一个网站,或者说是博客,我能干什么呢?

    首先自己有一些东西可以在这里分享,教程、软件之类的。分享是一种快乐,安利是一种美德。

    自己平时也会写一些东西,现在都是写在有道云笔记里自己看,以后也可以尝试在这个网站里面记录。所以这也决定了这个网站的定位,不是像很多访问量很大的个人网站那样以技术文章为主,这是我自己的空间,会加入我自己的生活。

    最后还可能会放一些专业性的东西在里面,或许会和以后的工作有关。

    既然网站已经搭建完成,那么第二篇文章当然要写怎么搭建网站。网上很多教程,自己多方综合,应该还是算比较完善的。那么,开始吧!

    1 购买域名和VPS

    我们访问网站的时候输入的是一个地址,而网站是放在远程的服务器上,这也就是搭建个人网站最基本的需要掏钱的地方:域名、服务器。

    1.1 购买域名

    域名推荐上阿里的万网购买。输入想要的域名,查询,不同的后缀有不同的价格,选择想要的域名购买就行。这里推荐选好域名后把相应的各种帐号都注册了,邮箱、百度、微信等,就算不用也能起一个保护作用。

    1456993840135849.png (947×554)

    1.2 购买服务器

    接下来考虑搭建网站的服务器。这里有两个选择,虚拟主机或者VPS。虚拟主机已经配置好网站运行环境,但是你只能在那个环境下玩;而VPS就是一个服务器,有自己的cpu内存等,可以自己装系统,灵活性可玩性更大。我们这里选择VPS。

    关于VPS的选择,有很多帖子可以参考,比如知乎这个问题有哪些便宜稳定,速度也不错的Linux VPS 推荐?,我也是在这个的推荐下选择了bandwagonhost的VPS。

    bandwagonhost一年20刀的VPS配置为:

    Location: Fremont CA (no other locations available on this plan)

    SSD: 10 GB

    RAM: 512 MB

    CPU: 1x Intel Xeon

    BW: 1000 GB/mo

    Link speed: 1 Gigabit VPS

    technology: OpenVZ/KiwiVM

    Linux OS: 32-bit and 64-bit Centos, Debian, Ubuntu, Fedora

    1 Dedicated IPv4 address

    Full root access

    购买地址

    下面关于bandwagonhost VPS的说明都是参考自搬瓦工vps

    从上面的购买地址进入bandwagonhost,选择按年付费,$19.99,不放心的可以先买一个月试试,$2.99。我就是先买一个月试了一下,感觉连接速度还不错,打算长期使用。

    1456995709197388.png

    Add to Cart→Checkout,然后会弹出一个相当于注册的界面,用拼音如实填写即可。

    1456995762423395.png

    最后付款选择PayPal或者支付宝,我这里是用PayPal。PayPal只要有储蓄卡就能用付款,去PayPal官网注册,绑定储蓄卡即可。具体的支付界面这里就不贴出了,主要是我暂时没有付款的需求。

    好了买下后去VPS后台看看。Services→My Services→KiwiVM Control Panel

    注意如果先买的一个月,后来要把账单周期改为一年,也在My Services中更改。Billing: Annually [modify],下面这张图上暂时没有出现,后来就有这个选项了。

    1456995968332049.png

    然后就进入如下的界面,可以看到自己VPS的IP。

    1456996043470041.png

    这里也没有过多需要说的,因为摸索两分钟就都能明白是什么了。

    左边的Main controls显示主界面,包括运行状态,开关机重启等操作;Detailed statistics可以监控运行状态;Install new OS可以安装新的系统;Shadowsocks Server一键安装SS,可用于爬墙,简直人性化。

    这里说明一下Status:LA: 0.00/0.00/0.00,这是Linux显示负载的方式,分别是1分钟、5分钟、15分钟内系统的平均负荷,1代表满载,可能出现超过1的情况。

    1.3 域名解析

    好了,域名有了,VPS也有了,可以进行域名解析了(把域名指向网站空间IP)。

    进入阿里云的管理控制台,点击域名菜单,在自己的域名后面点击解析。

    1456996192274358.png

    如下图设置,IP填写VPS的IP,主机记录填www代表将域名解析为www.jwcyber.com,填写@代表将域名解析为jwcyber.com,两个都写上吧,后面我们会用301重定向让它们都能使用。解析需要等待一段时间才会生效,我们先开始搭建网站。

    1456996268458395.png

    2 安装网站运行环境LNMP

    2.1 WordPress介绍 VPS安装系统

    我这里使用WordPress来搭建网站。WordPress是一种使用PHP语言开发的博客平台,用户可以在支持PHP和MySQL数据库的服务器上架设属于自己的网站。也可以把 WordPress当作一个内容管理系统(CMS)来使用。WordPress有许多第三方开发的免费模板,还有成千上万个各式插件,安装方式简单易用。

    不管怎样,只要知道WP国内外用的人很多就行,经过大家检验的肯定不错。(用了后才知道不管什么问题都能搜到解决方案。)

    下面的步骤都是依据搬瓦工VPS安装WordPress详细图文教程进行的。

    首先在Main controls中stop,然后Install new OS,选择centos-6-x86,Reload。

    在接下来的界面中记住 root password 和 SSH Port!

    1456996846167712.png

    安装好centos系统以后,就可以通过SSH连接VPS安装网站环境了。这里需要使用一个软件:putty

    运行putty,输入IP和SSH Port,Open。这里可以save一下,方便以后使用。

    1456997030902655.png

    进入的界面后,login as: root,回车;需要password,复制之前保存的密码,右键粘贴,回车就可登录VPS。(putty中鼠标右键为粘贴。)

    1456997087651103.png

    2.2 安装LNMP环境

    putty登录VPS后就可以安装网站的环境了,这里使用LNMP一键安装包,详细查看LNMP官网

    LNMP一键安装包是一个用Linux Shell编写的可以为CentOS/RadHat/Fedora、Debian/Ubuntu/Raspbian VPS(VDS)或独立主机安装LNMP(Nginx/MySQL/PHP)生产环境的Shell程序。WordPress就依靠这些环境运行。下面的步骤我直接粘贴LNMP官网的教程

    安装步骤:

    2.2.1 screen

    使用putty或类似的SSH工具登陆VPS或服务器;登陆后运行:screen -S lnmp

    如果提示screen: command not found 命令不存在可以执行:yum install screen 或 apt-get install screen安装,详细的screen教程

    2.2.2 下载并安装LNMP一键安装包

    您可以选择使用下载版(推荐国外或者美国VPS使用)或者完整版(推荐国内VPS使用),两者没什么区别,只是完整版把一些需要的源码文件预先放到安装包里。安装LNMP执行:

    wget -c http://soft.vpser.net/lnmp/lnmp1.2-full.tar.gz && tar zxf lnmp1.2-full.tar.gz && cd lnmp1.2-full && ./install.sh lnmp

    按上述命令执行后,会出现如下提示:

    11.png

    需要设置MySQL的root密码(不输入直接回车将会设置为root),输入后回车进入下一步,如下图所示:

    12.png

    这里需要确认是否启用MySQL InnoDB,如果不确定是否启用可以输入 y ,输入 y 表示启用,输入 n 表示不启用。默认为y 启用,输入后回车进入下一步,选择MySQL版本:

    13.png

    输入MySQL或MariaDB版本的序号,回车进入下一步,选择PHP版本:

    14.png

    输入PHP版本的序号,回车进入下一步,选择是否安装内存优化:

    15.png

    可以选择不安装、Jemalloc或TCmalloc,输入对应序号回车。

    提示”Press any key to install…or Press Ctrl c to cancel”后,按回车键确认开始安装。LNMP脚本就会自动安装编译Nginx、MySQL、PHP、phpMyAdmin、Zend Optimizer这几个软件。

    安装时间可能会几十分钟到几个小时不等,主要是机器的配置网速等原因会造成影响。

    2.2.3 安装完成

    如果显示Nginx: OK,MySQL: OK,PHP: OK

    16.png

    并且Nginx、MySQL、PHP都是running,80和3306端口都存在,并Install lnmp V1.2 completed! enjoy it.的话,说明已经安装成功。

    安装时间比较长,我花了刚好30分钟。最后的界面可能和上面教程不同,只要出现enjoy it就行。下面是我安装完成的截图:

    17.png

    2.3 添加虚拟主机

    经过上面的操作,已经安装完成网站的运行环境LNMP,接下来需要创建虚拟主机添加网站。(下面的操作说明搬自banwagong.com

    • 通过SSH连接到VPS,连接后输入命令 lnmp vhost add 。创建虚拟主机的过程是一个交互式的页面,集中截图到了一起,这里就细说一下。
    • 首先会要求你输入域名,输入好域名回车,会显示是否添加其他域名。我在这里一般是选n,不添加其他域名,然后在通过301重定向不带www的域名到带www的域名。
    • 然后就是网站的路径,默认的是/home/wwwroot/yourdomain 。如果不打算更改的话,直接回车就好,想自定义路径的话直接输入自己想要的路径就好了。
    • 然后就是是否允许Rewrite。这里建议选择y。lnmp自带了几种常用网站的伪静态规则,因为我们要安装的是wordpress,直接输入wordpress就可以了。
    • 再下面一部是是否开启访问日志。搬瓦工小硬盘的套餐的话,不建议开启,毕竟硬盘资源有限。
    • 再接下来就是创建数据库,这里如果要创建的话,会创建成一个用户名和数据库名相同的。
    • 如果选择y的话,会要先验证MySQL的root密码。验证后会让你输入数据库名,回车后会提示你,已经创建了一个和数据库名相同的用户名。然后就是输入数据库的密码。
    • 再回车以后就跳到最后一步,按任意键创建虚拟主机。

    18.png

    当出现上图最后的画面时,你的虚拟主机已经创建成功了。

    当然,这里的各项配置是可以通过修改配置文件进行更正的。所以没必要太纠结。通过vi修改或者下载到本地修改都可以。虚拟主机配置文件在:

    /usr/local/nginx/conf/vhost/域名.conf

    3 安装WordPress

    通过上面的步骤已经安装好了VPS搭建网站所需的环境并创建好了主机,接下来就是上传网站文件完成网站的安装。

    3.1 上传WordPress网站文件

    我们需要一款ftp软件,这里使用的是Filezilla。之前的环境搭建中,并没有安装ftp服务,所以使用sftp上传网站文件。

    在Filezilla主页中点击文件→站点管理器,具体设置如下图,注意端口要填正确,协议选择sftp。登录类型选择正常就好,用户名密码填好点击连接即可。

    19.png

    连接之后建议先进入/home/wwwroot/default 删除其中的如下图所示选中的文件,同时修改phpmyadmin的目录名,改为不容易猜到的。

    很多人问这一步的原因,根据评论中SEOIMO所说:

    default这个文件夹是系统默认的,里面是一些安装的信息,比如数据库和探针地址,为了安全起见,应该将里面文件改名或重建。而域名是建立在/home/wwwroot/文件夹下的,和default同层的。 除了数据库外,不用太在意default里面的内容,因为建站并不在此文件夹内。

    20.png

    然后进入到网站的安装目录,即上面的www.jwcyber.com文件夹,把网站的源文件上传到根目录里就可以了。当然,先得先去中文官网把wordpress的安装文件下载下来。

    解压后用Filezilla直接上传WP的网站文件,由于全是小文件,这将是一个非常漫长的过程。文件上传完成后的文件结构如下图所示(WordPress的网站文件直接位于www.jwcyber.com文件夹下):

    QQ截图20160418011340.jpg

    如果觉得上传太慢,可以先将网站文件压缩成zip压缩包,上传到VPS后再解压。打包的时候直接多选文件打包成1.zip,方便解压。

    压缩包上传完成后,通过SSH连接到VPS,进入网站的安装目录,命令为:

    cd /home/wwwroot/www.jwcyber.com (换成你自己的安装目录即可,注意cd后面有空格)
    

    进入后执行命令 unzip 1.zip 回车即可。

    21.png

    解压后要使WordPress的网站文件直接位于www.jwcyber.com文件夹下,和上面的截图一样,否则使用Filezilla移动一下文件。出现403错误的基本都是这个问题,我一开始也犯过,评论中看到很多人也犯过这个错误。

    然后等待域名的解析生效以后,就可以安装网站了。

    3.2 安装网站

    输入网址www.jwcyber.com,如果出现的是LNMP界面,则在VPS的管理界面里面重启一下VPS;如果是下面的WordPress的界面,证明前面的操作都没有问题,可以进行WordPress的配置了。按照下面的截图进行配置就行了。

    1456999470114025.png

    1456999487346443.png

    1456999503100994.png

    1456999532700394.png

    欢迎使用WordPress!

    到这里,用VPS LNMP WordPress搭建个人网站就基本完成了。

    27.png

    写在后面

    根据上面的教程,可以零基础利用VPS LNMP WordPress搭建出一个网站来,不过最终的到的只是一个可以访问的界面,离真正的个人网站还差得很远。

    还需要下功夫的地方主要有两个:界面和内容。WordPress很强大,众多的主题和插件,需要慢慢去研究。而内容,则是核心所在,没有内容,网站做得再漂亮也是白搭。我其实对于我是否能够把这个博客长久运行下去也是没有十足信心的,我基本没怎么发过原创内容,加上自己写东西确实不行,想要多产出内容是很难的。前面说过我想用这个网站干什么,那么今后就朝着那些方向前进吧。

    不过首先,得把网站的内容完善了,现在只是随便装了一套主题。下一篇文章应该就是WordPress使用中遇到的一些问题,包括301重定向,编辑器说明等。

    加油!

    WordPress使用常见问题

    1 提示需要输入FTP信息

    2 301重定向jwcyber.com到www.jwcyber.com

    3 WordPress只显示一个主题

    4 自带编辑器不够用

    5 为文章添加目录

    6 网站导航菜单

    7 Gravatar头像不能加载或者加载缓慢

    8 使用百度统计分析网站

    9 添加站点地图

    10 文章内容分页

    11 使用七牛云为已备案网站加速

    后记

    时隔一年多,想给博客换个服务器,又翻出了这篇文章。

    一年半的时间里,这篇文章的阅读量达到了5W,从评论和Pingback来看,应该有不少人照着这篇文章搭出了自己的博客。高兴!当初自己也没想着要把这篇建站教程写得多么好,随便截了截图就放上去了,今天来看实在写得有点粗糙,但也不想改了,就这样吧。

    本文写于2016年3月,到现在(2017年10月)已经有段时间了。这期间LNMP从1.2升级到了1.4,WordPress也从4.4升级到4.8了,这篇文章的时效性已经不强了,但基本思路还是没有变,而一些关键的地方我也写了出处,所以照着做还是没问题的。基本流程还是:购买VPS和域名、安装LNMP(看这里就行)、安装WordPress。一开始可能还需要对着教程看,熟悉之后其实就不用了,因为每个步骤实际上都有提示。

    最后,祝大家都能有一个长期更新的博客。

    附:现精简版WordPress安装流程

    1、购买VPS空间,可选择VultrLinode日本机房,VPS安装Ubuntu 16.04系统。(现在此网站又换成了腾讯云)

    2、FileZillaXshell用root账号登录VPS。

    3、安装BBR加速

    升级Linux至最新内核(4.12+)

    wget --no-check-certificate -qO 'BBR.sh' 'https://moeclub.org/attachment/LinuxShell/BBR.sh' && chmod a+x BBR.sh && bash BBR.sh -f
    

    一键安装BBR

    wget --no-check-certificate -qO 'BBR_POWERED.sh' 'https://moeclub.org/attachment/LinuxShell/BBR_POWERED.sh' && chmod a+x BBR_POWERED.sh && bash BBR_POWERED.sh
    

    4、安装LNMP

    wget -c http://soft.vpser.net/lnmp/lnmp1.4.tar.gz && tar zxf lnmp1.4.tar.gz && cd lnmp1.4 && ./install.sh lnmp

    默认安装即可,记下MySQL密码,整个过程30分钟左右。

    5、万网购买域名,解析至VPS的IP地址。

    6、添加虚拟主机

    lnmp vhost add

    根据提示安装,记下数据库名/用户名和密码。

    7、下载WordPress,将zip上传至</home/wwwroot/域名/>下,使用Xshell cd至该目录,unzip解压,确保wp-admin等文件直接位于域名文件夹下。

    8、更改文件夹权限:

    chmod -R 755 /home/wwwroot/jwcyber.com
    chown -R www /home/wwwroot/jwcyber.com
    

    9、在</usr/local/php/etc>下的php.ini中删去scandir函数,重启php进程。

    /etc/init.d/php-fpm restart
    

    10、浏览器输入域名,进入WordPress初始配置页面,输入之前记录的数据库等,完成安装。

    11、进入WordPress。全新安装的这时就可以开始折腾了;非全新安装,使用UpdraftPlus插件或者工具->导入恢复数据,还原至之前状态。


    喜欢 (162)
    发表我的评论
    取消评论

    表情 贴图 加粗 删除线 居中 斜体 签到

    Hi,您需要填写昵称和邮箱!

    • 昵称 (必填)
    • 邮箱 (必填)
    • 网址
    (258)个小伙伴在吐槽
    1. 之前试过各个步骤都是ok的,现在从LNMP那步就提示错误了,是因为lnmp原来的链接不可用了么。有没有更新的脚本呀,感谢。
      Nathan2019-07-21 21:22 回复
      • 很久没有关注过这个了,现在只能靠你自己去尝试了
        jwcyber2019-07-24 23:42 回复
    2. 博主因为ssr使用了80端口导致nginx没法正常工作怎么办啊?
      ioroyagami2019-05-29 01:30 回复
    3. 博主你好,我想用一台服务器搭建两个不同的网站,但是第二个搭建的时候,出现了500 Internal Privoxy Error,请问怎么解决
      白白2018-09-12 10:13 回复
      • 我没有遇到过,帮不上忙了
        jwcyber2018-09-12 22:45 回复
    4. 感谢博主用心的文章,小白我学习了
      Mr_Zthan2018-09-07 12:44 回复
    5. 按教程成功搭好了,谢谢博主的分享,转载到我空间了~已注明出处,学习中...
      hps2018-08-28 21:47 回复
    6. 楼主,我的FTP连不上我的vps服务器是咋回事呀? 端口确定是26714?
      ccc2018-08-27 09:10 回复
      • 我的是这个,你的不是这个,在VPS管理界面应该能看到SSH Port
        jwcyber2018-08-27 23:13 回复
    7. 博主可以转载吗?我会出处的~
      hulin2018-08-26 15:14 回复
      • 当然可以
        jwcyber2018-08-26 15:15 回复
    8. 您好,我试着用这种方法,但是最后总是提示数据库连接错误,感觉像是数据库配置问题,想请问可否帮忙看下,我在网上试了各种方法都不行,超级感谢
      bbikks22018-08-21 23:38 回复
    9. 安装好后出现的是LNMP界面,重启了vps也没用,还是这样
      但凡2018-07-23 09:51 回复
      • 感觉像wordpress文件没放对
        jwcyber2018-07-23 19:26 回复
    10. 我的按照上面做了,就是最后输入网址什么都不显示啊!直接说的是未发现页面
      WDKM2018-07-19 21:51 回复
    11. 第三部分 安装WordPress部分,不能直接通过putty 向安装其他文件一样安装 WordPress程序吗,教程里面的是通过Filezilla上传的WordPress的安装包
      will2018-07-14 11:10 回复
    12. 成功啦,感谢感谢 :oops:
      大胡子艾米2018-06-05 18:25 回复
    13. 大神,我按照这个教程做下去了,成功过一次,但是换了一个服务器以后,在ip/phpmyadmin/这个地方,网页是空白的,什么都没有,无法创建wordpress的数据库,请指教。
      xin2018-06-05 01:21 回复
    14. 大神,我的ip地址输了出来的是正确的博客界面,输入域名就是找不到服务器IP、找不到DNS之类,域名解析也做了,这是怎么回事呀?
      2018-06-01 16:35 回复
      • 你ping一下你的域名,看是你的ip吗
        jwcyber2018-06-01 23:21 回复
    15. 感谢 哈哈 已成功 :idea:
      一颗红心向党2018-05-24 19:07 回复
    16. 求助,我安装的wordpress网站,安装在了vultr上,但是发现我用无论家里或者公司的ip都进不去,我用其他其他vps的IP也进不去,必须要用我自己注册的vultr ip才能进入这个网站,请问是什么原因导致的这个问题啊?是因为我在vps端装的防火墙吗?
      NovicePQ2018-05-15 14:52 回复
      • 用我自己注册的vultr ip指的是?
        jwcyber2018-05-16 23:58 回复
      • 我操,我也遇到了这个问题
        www2018-07-10 20:10 回复
    17. 很详细!一步一步跟着成功搭建了WP网站!欢迎访问
      有意思小事2018-03-14 23:20 回复
      • 目测挂掉了/哭笑
        jwcyber2018-03-15 00:09 回复
        • hhh 是国外的服务器和域名,可能国内访问不了
          有意思小事2018-03-15 19:07
    18. 感恩!本小白也成功啦~
      ninomi2018-03-10 17:50 回复
    19. 感谢老哥,根据教程搭建成功,但是最大上传文件是50M,有的VPS更是2M,根据谷歌出的回答修改php.ini文件upload_max_filesize = post_max_size = max_execution_time = 几个参数后再上传文件页面确实看到效果了,但是上传过程中到达50M大小后会出错,进度归零重新开始一直循环此过程,这应该是只是表面显示可以上传大于50M但实际限制还是50M,老哥有方法吗?
      anatakolewa2018-02-17 20:36 回复
      • 我貌似没有处理这个问题。大于50M的文件直接用FileZilla传?
        jwcyber2018-02-18 21:58 回复
    20. 你好,打扰了,有些问题想咨询下: 博客里用和对于seo有什么区别吗? 还有就是我的网站的主页上每篇文章都有一个h1标签,导致主页那块能找到十几个h1标签,需要修改下吗? 如何才能让主页的文章标题变成h2呢
      R2017-12-29 11:19 回复
      • 关于SEO的问题我也没研究过。我没有进行过设置,标题直接都是H2。
        jwcyber2017-12-29 22:00 回复
        • 是主题的style是默认H2的吗,我看我的主页里的文章全是h1的
          RE2017-12-29 23:11
        • 应该主题默认就是H2。因为怕主题切换后出问题,我这边也不方便测试。刚随便找了几个Wordpress站点,发现有H1也有H2的。
          jwcyber2017-12-30 00:43
    1 2 3