搭建自己的前端服务器环境—Node、MySQL、Git和Nginx等一网打尽
liuian 2025-05-11 17:05 6 浏览
前言
作为前端开发者一直都在关注浏览器的行为、表现。但是时间长了免不了要接触到后端的知识、服务器的知识。尤其是在前端技术爆发式发展的当下,前端慢慢的渗透到了更多的领域。比如,使用 express/koa 创建 http 服务,使用React-Native开发Android和IOS通用的APP,甚至使用node开发系统、嵌入式程序等。这个时候,我的内心开始蠢蠢欲动,我们能做的不仅仅是网页。虽然我是个前端,但是我有一颗全栈的心啊,正好之前入手了阿里云的服务器,这周闲来无事,折腾起来。
创建自己的服务器
我这里推荐使用云服务器,相比使用自己的服务器,云服务器有很多方便的地方,而且云服务器提供一个一周的试用版,用起来非常的方便。
创建一个轻量级的服务器 阿里云可以购买一台可使用一周的服务器,这个服务器正好用来做这次开发(已有的请跳过)。
登录阿里云,进入购买 CES 的地方,链接地址如下:
https://www.aliyun.com/[1]
依次选择:
o计费方式:包年包月。
o地域:华北5(当前华北5有优惠)。
o实例:请寻找1vCPU、1G内存的实例(我最终选择了突发性能实例 t5)。
o镜像:选择CentOS 7.4 (现在后端普遍使用6+的版本,7相比6有了很大改进,前端选择7可以减少很多麻烦),勾选安全加固。
o云盘:40G高效云盘。
o公网带宽:勾选自动分配公网 IP,选择1M带宽。
o安全组:选择默认安全组,并勾选http80端口和http443端口。
o购买周期:选择1周。
最终结果:
我们的服务器主要做网站类的开发,所以有针对性需求的用户可以考虑将内存增大,其他在需要的时候采取考虑。
安装自己的开发环境
Windows连接到服务器
Linux服务器不像window那样有一个可视化的界面,window/mac连接的时候也不像远程桌面那样方便。这里连接服务器需要使用命令才行。
window连接服务器 好消息是window下有一款神器:xshell,命令可以很方便的输入到一台服务器或者多台服务器上,用户密码也可以很方便的保存在本地,多个服务器还可以分组,你要做的就是专注于眼前的服务器开发。
这个软件可以直接百度下载。
o首先你需要安转一个xshell,下载需要填一些信息,安装非常简单,要注意的是安装的时候需要选择个人开发使用,不然安装好之后发现需要交钱才能用就坑了。
o安装好之后你就可以把自己的服务器ip、用户名、密码都填好了,以后只需要鼠标一点就进入了自己的服务器了。
o需要注意的是,选择一下默认的字符,不然你的中文会变成乱码。
o连接之后的界面是下面这样。
o首先有一个进入服务器的提示,然后下面就是熟悉的命令行了,不同的是前面那段显示的规则是用户名@机器名。
Mac连接服务器
Mac连接服务器可以使用自带的终端应用,也可以自己下载一个iTerm2,这里我推荐使用iTerm2,可以方便的使用不同的主题,添加各种有用的插件。
o打开iTerm2,输入连接命令ssh 用户名@ip地址然后回车,你会看到提示你输入密码,这个时候输入你在购买服务器的时候设置的密码就好了。
o只要密码正确,你就可以进入服务器了,依旧是熟悉的命令行模式。
o你会在第一时间看到服务器反馈的上次登录信息,欢迎信息,然后是命令行的提示,前面的显示规则是用户名@机器名。
几个常用的命令 要想使用Linux系统服务器做开发,不懂几个常用命令怎么行?
ossh 用户名@ip,连接服务器的命令。
ocd 绝对路径/相对路径,跳转到路径对应的目录下。
orm 文件名,删除文件。
orm -rf 目录路径,删除目录以及目录下的所有文件,谨慎操作!
ols [-a],查看当前目录下的文件和目录,加-a参数可以查看所有文件,包括隐藏文件(.开头的文件是隐藏文件,默认是看不见的)。
oll,查看当前目录下的文件详情,可以文件的权限,遇到没有权限执行的情况下可以使用这个命令查看。
opwd,查看当前路径的完整路径,不知道自己在哪儿的时候可以使用这个命令查看。
owhich 名字,在几个默认位置查找改名字,比如查找pm2安装在哪个地方了。
omkdir 目录名,创建一个空目录。
ocat 相对/绝对文件路径,查看文件的内容,多为查看日志或者其他文本文件。
ocp 文件路径 目标路径,复制一个文件到另外一个地方。
omv 文件路径 目标路径,移动一个文件到另外一个地方,也可以重命名。
ops -aux,显示当前进程,有时候需要用这个查看进程是否存活。
okill -9 进程id,结束进程,进程id就是上一条命令查到的pid。
otar -zxvf 文件,解压缩文件。
otar -zcvf 压缩后的文件 要压缩的文件/目录,压缩文件。
ovi 文件路径,使用vim进入文件的编辑模式。
ovi退出文件,按下esc键保证退出编辑模式,输入:q或者:q!强制退出。退出保存输入:wq
ovi编辑,按下i左下角会提示进入编辑模式,然后就是正常的输入文字,再按esc键退出编辑模式。
ovi保存编辑结果,按下esc键保证退出编辑模式,输入:x保存并退出
安装Node
1.推荐安装最新的稳定版。我这里是10.15.3,下载地址如下:
https://nodejs.org/en/download/[2]
2.选择Source Code后面的那一行,右键复制链接地址,我们使用源代码的方式安装,第一次安装的时候使用这种方式好处多多。
3.回到服务器,首先跳转到根目录下cd /。创建一个空目录,用来放所有的安装包mkdir software。
4.使用命令把刚才的文件下载下来wget
https://nodejs.org/dist/v10.15.3/node-v10.15.3.tar.gz。阿里云下载速度比较给力。
5.将下载好的压缩包解压tar -zxvf node-v10.15.3.tar.gz:
6.进入解压好的目录并执行config配置命令cd node-v8.9.4.tar && ./configure
7.在编译代码之前,还需要在机器上安装一些软件包,使得编译可以正常运行: sudo yum install gcc gcc-c++
8.执行编译以及安装命令make && make install,这里编译阶段时间会非常长,你可以喝杯茶,真的超级长,别怪我没提醒你。编译成功后执行npm -v和node -v测试是否安装成功。
安装MySQL
mysql是一个方便使用的开源数据库。因为使用简单,安装方便,功能强大,受到很多开发者的喜爱,给自己安装一个MySQL数据库真的是非常有必要的,利用它可以存储不少东西。
1.下载安装需要用到的源:
wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm[3]
2.安装下载的源rpm -ivh
mysql-community-release-el7-5.noarch.rpm
3.下载安装MySQL:yum install mysql-server
4.使用service mysqld start
5.使用命令修改当前用户的密码(默认root是没有密码的):mysqladmin -u root password '密码',这里我设置的密码为root
6.使用命令进入数据库:mysql -u root -p
7.这个时候数据库已经安装好了,但是只能在服务器上看。我们需要让MySQL运行远程连接,这样方便我们调试,不用每次都要使用命令行。
8.进入服务器的mysql命令行模式下,输入GRANT ALL PRIVILEGES ON . TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;其中root代表的是这次要修改的用户名,password代表这个用户使用的密码,然后再输入flush privileges;让命令生效。需要注意的是每行命令的最后要加;,不然是不会执行的。
9.如果顺利,这个时候已经是修改完了,你可以输入查询命令来看看最终的结果。SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user;。也可以通过软件直接登录数据库看看。
10.到此MySQL数据库就完成安装了,这个时候可以使用某个客户端连接上数据库看了(推荐navicat for mysql),也可以直接进入服务器的命令行模式查看数据库。
安装 Nginx
Nginx 真的是现在必不可少的一个软件。在转发请求、负载均衡等方面非常非常的有用。这里我们先简单的使用nginx的端口转发代理等几个功能。它可以将几个不同的服务集中在一个80端口下,根据域名或者请求路径来区分。
1.注意,在安装nginx之前还需要安装几个nginx的依赖插件。
2.安装pcre yum install -y pcre pcre-devel:
3.安装zlib yum install -y zlib zlib-devel
4.安装openssl,这个推荐安装,毕竟大家都在使用https证书了,yum install -y openssl openssl-devel
5.下载源代码,复制下载地址,并使用wget命令下载到服务器上,下载地址如下:
https://nginx.org/en/download.html[1]
6.解压下载的文件并进入解压好的目录tar -zxvf nginx-1.13.8.tar.gz && cd nginx-1.13.8
7.执行配置命令./configure
8.继续编译安装nginxmake && make install
9.查看安装结果whereis nginx
10.跳转到安装好的nginx目录下,进入sbin目录cd /usr/local/nginx/sbin
11.启动nginx./nginx
o./nginx,启动nginx;
o./nginx -s stop,停止nginx;
o./nginx -s quit,退出nginx;
o./nginx -s reload,重启nginx。
12.安装成功后,使用IP公网地址即可进行访问。
安装Git
centos上是没有安装git,而git是我们开发中经常要使用的工具,这里就讲一下怎么安装git。
1.在服务器上执行yum install git。如果上面的几个软件没有安装,您可能还需要安装几个依赖库,这个可以查看出现的错误来决定安装那些库。
2.确定一下git是否安装完成git --version
总结
至此为止,一个简单的前端环境就已经安装好了,你可以把你的项目通过git扔到服务器上进行访问了,如果你觉得我的文章对你有所帮助,多转发多关注都是对我莫大的鼓励,[
相关推荐
- HR必备Excel函数:4个与日期相关的计算函数。
-
提到日期函数,很多人首先会想到“today”,它可以显示当天的日期,并且每次打开表格时都会自动更新。但是,对于前天、昨天、明天和后天的日期,就不能用yesterday或者tomorrow等这些英文了,...
- 这篇文章有点长,但可以让你十分钟玩转Excel的时间函数
-
日期与时间函数——TODAY、NOW、YEAR、MONTH、DAY!如何用WORKDAY函数查询距离某天的第20个工作日是哪一天?如何用NETWORKDAYS函数查询员工工作了多少个工作日?如何用WE...
- Excel2020年日历套装,表格设计,农历显示,查阅套打轻松应用
-
Hello大家好,我是帮帮。今天跟大家分享一组Excel2020年日历套装,表格设计,自带农历控件,查阅套打轻松应用。有个好消息!为了方便大家更快的掌握技巧,寻找捷径。请大家点击文章末尾的“了解更多”...
- 巧用NETWORKDAYS函数计算两个日期之间工作日的天数
-
带有日期的单元格是我们日常使用EXCEL的时候经常见到的,有的时候我们需要求出两个日期之间间隔的天数,可以直接用结束日期减去开始日期即可,这是个非常简单的减法公式。不过这个单纯的减法公式会默认去掉开始...
- Excel按工作日、休息日进行汇总
-
1、按周六日/其它时间汇总为了区分一周的周六日和其它时间,可以使用WEEKDAY函数,把WEEKDAY函数的第2个参数指定为2,如WEEKDAY(A3,2),则周一返回1,周二返回2,…,周六返回...
- 如何计算每月应出勤天数,如有法定假期和调休,如何计算
-
本文介绍如何计算每月的应出勤天数。第一部分介绍正常双休制下计算应出勤天数;第二部份介绍当月有法定假期和调休的情况下计算应出勤天数。一、计算正常双休制的应出勤天数如下图所示,要求计算各员工2021年3月...
- 《Excel一键生成工作日历:让会议排期更轻松!》
-
每当需要安排会议时,总要翻看日历确认工作日,再逐个标注会议时间,既耗时又容易出错。今天教大家用Excel快速生成工作日历表,让会议排期变得简单高效!一、快速生成日历框架创建基础日期:在A1单元格输入月...
- 如何计算指定日期区间内,有多少工作日和休息日?
-
大家好,今天咱们要解决的问题是如何计算给定的一段日期内,正常工作日有多少天,放假时间有多少天?比如咱们要计算2025年3月份工作日一共有多少天,又有多少天放假,如下图所示:通过肉眼我们可以数清楚,20...
- 如何如何在表格中自动突出显示双休日?
-
现在不少人喜欢用Excel来制作备忘录或安排工作事项。在表格中输入日期后,可以使用条件格式突出显示双休日,避免在休息日安排了工作。具体方法是这样的:第1步:选择要设置条件格式的日期单元格区域;在“开始...
- excel函数技巧:networkdays.intl判断节假日
-
如图,想知道6月的每一天是否是节假日,公式如下:=NETWORKDAYS.INTL(A2,A2,1,$E$2:$E$28)这个函数既可以判断当前日期(一参=二参)是否是周末及工作日(三参、四参)还可得...
- 仅需3步,让考勤表根据实际休息日,自动地填充颜色
-
Hello,大家好,之前跟大家分享了我们如何让考勤表根据单休与双休自动的填充颜色,最近有粉丝问到:能不能让考勤表根据实际的休息日自动的填充颜色呢?可以是可以,只不过因为牵扯到假期调休,我们每年的休息日...
- 5步搞定动态考勤表!标记节假日、调休日?Excel自动变色!
-
今天教你用「动态考勤表」一招解决所有问题!只需输入月份,自动变色、自动更新节假日,从此告别加班,效率翻倍!动态考勤表的优势:自动变色:节假日、双休日一键标记,颜色分明。一表多用:修改月份即可...
- 一起用python做个炫酷音乐播放器,想听啥随便搜
-
前言前段时间写的Python自制一款炫酷音乐播放器,有不少小伙伴私信我,对播放器提了不少改进建议,让我完善播放器的功能。今天音乐播放器2.0版本完成了,大家一起来看看是如何用python自制一款炫酷的...
- 用Python做个“冰墩墩雪容融”桌面部件(好玩又有趣)
-
桌面太单调?今天就带大家,一起用Python的PyQt5开发一个有趣的自定义桌面动画挂件,看看实现的动画挂件效果!下面,我们开始介绍这个自定义桌面动画挂件的制作过程。一、核心功能设计实现将动态图gif...
- Python串口调试助手源码分享
-
以下是一个基于Python和PyQt5实现的串口调试助手示例,包含核心功能实现代码:pythonimportsysimportserialfromPyQt5.QtCoreimportQTim...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
python使用fitz模块提取pdf中的图片
-
《人人译客》如何规划你的移动电商网站(2)
-
Jupyterhub安装教程 jupyter怎么安装包
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- uniapp textarea (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- react-admin (33)
- vscode切换git分支 (35)
- vscode美化代码 (33)
- python bytes转16进制 (35)