阿里云ECS云服务器CentOS部署个人网站

news/2024/5/9 2:21:02/文章来源:https://blog.csdn.net/senupp/article/details/103776277

ping了一下coding pages和阿里云服务器的速度,意外感觉coding的速度反而更快。不过为了折腾,还是把博客迁移到阿里云,跌跌撞撞遇到很多坑,大多是由于对指令不熟悉以及部分教程省略了部分步骤,最后不断谷歌终于成功了!

购买学生机

一开始纠结了好久的问题是:阿里云学生机要买轻量应用服务器还是云服务器ECS?最后看着教程买了半年的云服务器ECS&Centos,因为参考的教程也是用的这种配置。但是我后悔了,前者的带宽峰值是后者的五倍啊啊啊啊!!!果然人一穷就想着要追求性价比,流下了穷人的泪水呜呜呜

阿里云配置:

找到云主机实例(这个实例就是你购买的ECS服务器)

找到服务器主机实例

找到服务器主机实例

  1. 在云服务器ECS列表中选择实例。
  2. 然后选择你在购买服务器时选择的服务器区域。
  3. 就是你自己的服务器实例了。

添加安全组规则

如果要使用CentOS镜像系统这个安全组规则是必须要添加的。
简单明了,下面用四张图来演示添加安全组规则。

进入实例管理

进入实例管理进入实例管理

进入安全组配置规则

进入安全组配置规则进入安全组配置规则

打开添加安全组规则

打开添加安全组规则打开添加安全组规则

添加安全组规则

添加安全组规则

添加安全组规则

好的,配置完成,很简单对不对,不过这还只是热身哦,接下来就要进入主题开始我们的搭建博客之旅。


服务器环境搭建

选择实例的远程连接

选择远程连接

选择远程连接

输入远程密码

输入远程密码

输入远程密码

注意:这里的远程密码,只有在第一次连接的时候会提示,只有在第一次连接的时候会提示,只有在第一次连接的时候会提示,重要的事情说三遍。一定要牢记。

登录服务器

输入密码后就会进到服务器页面,是一个黑色的shell小窗口,之后根据提示登录就可以。
shell窗口中的登录操作就不截图演示了,直接使用文本方式根据步骤来就可以了。
  1.login后面输入用户名。
  2.password后面输入密码。(注意:这里在输入密码的时候为了安全是不会在界面上显示出来的,所以如果你在输入密码的时候没有看到你输入的结果是正常现象,直接输入就可以)

安装git和nodejs

yum install git#安装Nodejs
curl --silent --location https://rpm.nodesource.com/setup_5.x | bash -
adduser git
chmod 740 /etc/sudoers
vim /etc/sudoers

到这里之后会打开一个文本文件,然后找到以下内容

Allow root to run any commands anywhere
root    ALL=(ALL)    ALL

按一下 I 键 进入插入模式然后使用方向键在以上内容的下面添加一行

git ALL=(ALL) ALL

添加完成后按下ESC键退出插入模式,然后输入

:wq

这个命令的意思是保存并退出vim
保存退出后改回权限

chmod 400 /etc/sudoers

随后设置Git用户的密码,

sudo passwd git

然后输入git用户的密码 输入完成之后一路回车等待设置完成之后
切换至git用户,创建 ~/.ssh 文件夹和 ~/.ssh/authorized_keys 文件,并赋予相应的权限

su git
mkdir ~/.ssh
vim ~/.ssh/authorized_keys
然后进入电脑中(你自己的电脑)C:\Users\Administrator\.ssh文件夹下看一下有没有id_rsa.pub文件
如果没有则通过Git Bash新建一个
创建.ssh命令为:ssh-keygen -t rsa -C "your_email@example.com"
创建好后在C:\Users\Administrator\.ssh文件夹下使用笔记本方式打开id_rsa.pub文件,打开后就能看到公钥了。
然后将公钥复制粘贴到authorized_keys 写入方式和上面在sudoers插入方式一样,完成之后执行下面命令
chmod 600 ~/.ssh/authorzied_keys
chmod 700 ~/.ssh

然后在客户端(电脑上),通过Git Bash执行ssh -v root@ip地址(就是你阿里云的外网地址) ,应该就能免密登陆了。

安装Nginx和配置

安装

yum install nginx

启动 直接输入nginx然后回车就可以启动nginx

nginx

然后把服务器的公网地址输入浏览器, 出现下面的图片就对了,没出来就有问题
nginx启动成功

nginx启动成功

配置Nginx

vim /etc/nginx/conf.d/default.conf

依照下图进行修改,插入方式往下就不做介绍了,就那几步,如果有不会的可以去百度一下。
img
listen:端口号。
server_name:你自己的域名,如果没有域名可以不填写,然后在访问博客的时候使用你服务器的外网IP地址就可以。
location:地址内容。
root:指向的博客文件夹目录。
index:指定博客Index文件。

配置完成以后保存退出开始执行接下来的内容

sudo mkdir -p /usr/share/nginx/html/blog
sudo chown -R git:git /usr/share/nginx/html/blog

nginx的配置到这里已经完成,接下来就要创建我们自己的私有git仓库了哦

在服务器上初始化一个git仓库

切换到git用户,然后切换到git用户目录,接着初始化裸库,代码如下:

su git
cd ~
git init --bare blog.git

接着新建一个post-receive文件

vim ~/blog.git/hooks/post-receive

然后在该文件中输入以下内容:

#!/bin/sh
git --work-tree=/usr/share/nginx/html/blog --git-dir=/home/git/blog.git checkout -f

这里的 #!/bin/sh 也是要加进去的,不要当成注释从而遗漏掉了哦。

保存退出之后,再输入以下代码,赋予该文件可执行权限。

chmod +x ~/blog.git/hooks/post-receive

好了,到这里我们的服务器配置已经完成。我们先喘一口气休息一下,回过头检查一下有没有遗漏或者出现错误的地方,出现差错到时候可能会导致配置不成功的,要仔细一点哦。

本地Hexo初始化

首先要安装 hexo-cli,安装hexo-cli 需要 root 权限,使用 sudo 运行

sudo npm install -g hexo-cli

然后初始化Hexo程序

cd E:\hexo
hexo init blog

等执行成功以后安装两个插件, hexo-deployer-git 和 hexo-server ,这俩插件的作用分别是使用Git自动部署,和本地简单的服务器。

hexo-deployer-git帮助文档
hexo-server帮助文档
安装hexo-deployer-git 和 hexo-server

cd blog
npm install hexo-deployer-git --save
npm install hero-server

初始化Nodejs

install nodejs

生成自己的第一篇文章 hello world !

hexo new "hello Hexo"

使用 hexo new 来新建文章,该命令会成成一个 .md文件放置在hexo根目录 source/_posts文件夹。
使用hexo g将 .md文件渲染成静态文件,然后启动hexo-server

hexo g
hexo server

现在便可以打开浏览器访问 http://localhost:4000 来查看我们的博客了!

然后停掉

配置_config.yml,完成自动化部署

然后打开E:/hexo/_config.yml 找到 deploy

deploy:type: gitrepo: root@YOUR_SERVER_IP:/home/git/blog.git       #此处的YOUR_SERVER_IP需改为你自己服务器的ipbranch: master                                     #这里填写分支message:                                           #提交的信息

hexo_config配置

hexo_config配置

保存后,尝试将我们刚才写的”hello hexo”部署到服务器

hexo clean
hexo g
hexo s
hexo generate --deploy

访问服务器地址,就可以看到我们写的文章”Hello hexo”,以后写文章只需要:

hexo new "Blog article name"
···写文章
hexo clean
hexo g
hexo s
hexo generate --deploy

到这里我们的博客就已经可以使用了。现在快去体验一下自己的劳动成果写博客部署上去吧。

配置域名

阿里云域名解析处-新手引导-添加主机地址,就可以自动创建两条记录。

OVER


遇到的问题:

CentOs下nginx的配置文件

是放在/etc/nginx/nginx.conf,而不是nginx.default。

mark


Nginx启动失败,原因是80端口被占用。

使用命令关闭占用80端口的程序

sudo fuser -k 80/tcp

或者是

遇到这种问题我先用中文搜索了一下答案,发现大家都在装逼地说要杀nginx重复的进程。我试了下发现是扯淡,于是看了谷歌搜到的第一个英文页面,老外说是nginx先监听了ipv4的80端口之后又监听了ipv6的80端口,于是就重复占用了。更加坑人的是你去看了端口占用它又把80端口释放了,是不是很囧。

解决方案是编辑nginx的配置文件

hankcs@ubuntu:~$ sudo gedit /etc/nginx/sites-available/default

修改这一段:

listen 80;listen [::]:80 default_server;

listen 80;listen [::]:80 ipv6only=on default_server;

然后启动nginx,完美解决!


ssh登录失败

大部分原因是由于.ssh目录下的known_hosts中

47.98.147.134 ecdsa-sha2-nistp256 

出错,删除这一段代码即可。


参考教程

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_859986.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

cnblogs博客园修改网站图标icon

比特虫&#xff0c;图片转换成ico图标 上传到博客园文件 修改网络地址即可 <script type"text/javascript" language"javascript">//Setting ico for cnblogsvar linkObject document.createElement(link);linkObject.rel "shortcut icon&quo…

我们是怎样毁了社交网站的?

我们是怎样毁了社交网站的&#xff1f; 共分享4次 ahxxm发布于2014-02-08 14:48:18 作者&#xff1a;Nathan Mattise 文章来源&#xff1a;ArsTechnia 我在录取通知书中看到 2005 年时学校给的电子邮箱地址&#xff0c;回想起当时打开录取通知书后&#xff0c;我就直奔电脑前…

在线制作简历的网站

1 超级简历 2 乔布简历

一个神奇的网站 Papers with code

这个网站会把某个方向的 论文和代码总结出来。 有助于提高个人效率。 https://paperswithcode.com/sota

高清桌面壁纸网站

这个网址&#xff0c;可以下载高清的桌面壁纸&#xff0c;感觉不错。 https://www.ivsky.com/bizhi/

一个用于网站自动化测试的生态系统实现

这是我在从事网站自动化测试的工作当中构建出的一个“生态系统”。“生态系统”这个概念是我从公司的前辈身上学到的&#xff0c;他一直以来都认为自动化测试人员不应仅仅局限于编写测试代码&#xff0c;还应该让整个自动化测试的过程&#xff08;测试代码的持续集成、分发、执…

搜索引擎抓去网站内容的工作原理简单介绍

今天郑州SEO简单介绍一下关于搜索引擎抓取系统中有关抓取系统基本框架、抓取中涉及的网络协议、抓取的基本过程三部分。 互联网信息爆发式增长&#xff0c;如何有效的获取并利用这些信息是搜索引擎工作中的首要环节。数据抓取系统作为整个搜索系统中的上游&#xff0c;主要负责…

环境部署--搭建网站(1)

第一步&#xff0c;申请域名 国内比较知名的注册域名的网站是万网和新网。我是在新网注册的。 第二步&#xff0c;申请空间 购买空间 我用的是腾讯云&#xff0c;操作步骤如下。 进入腾讯云首页&#xff0c;购买云服务器。 这里相当于给你一台机器归你试用。这里应该是用的虚拟…

PHP 网站优化之页面静态化

页面静态化是提高网站访问速度的一个很好的优化方法&#xff0c;可以提高网站50%以上的访问速度&#xff0c;但是也有缺点&#xff0c;就是换的数据无法及时更新。 那页面静态化是如何实现的呢&#xff0c;就是把PHP生成的动态页面保存成静态的html文件&#xff0c;用户访问该静…

网站性能分析及优化方法

服务器端 负载均衡 LVS 简介&#xff1a; LVS是一个开源的软件&#xff0c;可以实现LINUX平台下的简单负载均衡。LVS是Linux Virtual Server的缩写&#xff0c;意思是Linux虚拟服务器。 分为三层结构 1.负载调度器 2.服务器池 3.共享存储 优点&#xff1a; 1、开源&#xff0c;…

Mysql官方网站到底该如何下载、安装?(超详细教程)

第一步搜索MySQL:https://www.mysql.com/ 第二步找到下载地址 点击进去后往下翻&#xff0c;能看到 这就是我们要下载的了&#xff0c;点击进入 不要选错了 选择下载第二个&#xff0c;一次性下载安装 前一个也可以&#xff0c;包比较小&#xff0c;但是是一边下载 一边安装&a…

444day(mouseover与mouseenter不同,过滤选择器)

《2018年12月21日》【连续444天】 标题&#xff1a;mouseover与mouseenter不同&#xff0c;过滤选择器&#xff1b; 内容&#xff1a; mouseenter: 与mouseover的不同&#xff1a;http://www.w3school.com.cn/tiy/t.asp?fjquery_event_mouseenter_mouseover 过滤选择器&…

8个超棒的学习jQuery的网站

根据国外科技网站 W3Techs 一项调查了近100万个网站数据显示&#xff0c;jQuery是目前最流行的 JavaScript 库。对于初学者来说&#xff0c;有的时候很难找到一个好的学习jQuery的网站&#xff0c;所以本文收集了8个很棒的 jQuery 学习网站推荐给大家。 1. Learning jQuery 最…

批量爬取某图片网站的图片

批量爬取某图片网站的图片 声明&#xff1a;仅用于爬虫学习&#xff0c;禁止用于商业用途谋取利益 1、网页解析 &#xff08;1&#xff09;打开veer首页&#xff0c;F12(谷歌浏览器)&#xff0c;输入关键字&#xff0c;点击搜索&#xff0c;点击查看如图画圈位置 &#xff…

源码编译安装Nginx及网站服务配置

文章目录 一、Nginx概述1.1 Nginx概述1.2 Nginx和Apache的区别1.3Nginx和Apache的优缺点差异1.4Nginx的进程 二、源码编译安装nginx服务2.1关闭防火墙&#xff0c;将nginx所需压缩包放入/opt目录下2.2安装依赖包2.3创建运行用户和组&#xff0c;便于管理2.4解压软件包&#xff…

程序员实用工具网站

目录 1、搜索引擎 2、PPT 3、图片操作 4、文件共享 5、应届生招聘 6、程序员面试题库 7、办公、开发软件 8、高清图片、视频素材网站 9、项目开源 10、在线工具宝典大全 程序员开发需要具备良好的信息检索能力&#xff0c;为了备忘&#xff08;收藏夹真是满了&#x…

mouseover 和 mouseenter

不论鼠标指针穿过被选元素或其子元素&#xff0c;都会触发 mouseover 事件。 只有在鼠标指针穿过被选元素时&#xff0c;才会触发 mouseenter 事件。 <!Doctype html><head><script type"text/javascript" src"/jquery/jquery.js"><…

教会你如何在自己建立的网站上使用Mondrian和MDX语句对数据库查询

一个简单的Mondrian例子(部分参考某个大牛的文档~~)希望大家学到东西~ 可以详细参考豆丁网上的一个文档&#xff1a;http://www.docin.com/p-88928995.html 也可以跟我一起做~ 3.1 创建新的web项目 3.1.1 打开myEclipse,新建一个网站我的是这样的&#xff1a; 注意名字要按照…

网站建设的常识

1,整站DIVCSS步局&#xff0c;虽然写起来很痛苦&#xff0c;注意还要兼容FIERFOX浏览器 css: 1&#xff0c;通常用一个通用的CSS&#xff0c;每个页面都引用&#xff0c;公用的CSS全包含在里面&#xff0c;单个页面再做 一个CSS文件 2&#xff0c;背景图片&#xff0c;把页面用…

高并发高负载的网站架构

这一篇&#xff0c;主要是从技术的角度来阐述网站的架构和功能。在开始技术性的讨论之前&#xff0c;还要说一下前文没有解决的问题。第一是网站名字的问题&#xff0c;给网站取名字&#xff0c;确实很费了我的一番头脑&#xff0c;因为要做数码照片类的网站&#xff0c;又因为…