腾讯云服务器Ubuntu-配置mysql,nginx,nodejs
趁着618腾讯云服务器的促销活动,笔者买了最低配置的云服务器,用作学习。
接上一篇文章的内容,系统方面选择了Ubuntu,版本是20.04 LTS。
选择Ubuntu的原因,主要是因为Ubuntu一直是家用Linux中最流行的,网上有很多教程,学习很方便。如果真的要用于作正式服务器,还是主要推荐Debian或Centos。
那下面就从初次启动云服务器到基础配置完成的内容进行记录。
1、启动服务器
在腾讯云控制台的界面,可以直接登录服务器。
这个启动方式,会有个网页端的控制台,通过命令行的方式使用,如下:
这里还是不建议对linux安装图形界面,原因:
1)命令行的网络传输速率快很多;
2)图形界面会占用不少硬盘空间,对于学习用的低配置云服务器的硬盘容量就更少了;
3)linux还是有很多功能需要用命令行,就算有图形界面,还是会打开终端。
其实,云服务器只是用于管理项目,没有图形界面也不难实现。
启动后,看到右下有提示,输入sudo su root可切换至root,为了方便使用,先切换到root。
这里还是说一下,一般的Ubuntu的某些命令,都会在最开始写sudo 就是指使用root账号操作,
但如果切换了root账号后,这些命令就不需要再写sudo了,下文我会省略sudo。
2、安装mysql
更新源:
apt update
安装mysql:(-y就是让系统直接装,不会问是否确定要安装)
apt install -y mysql-server
到这里mysql就安装好了。
但是,为了方便以后的访问,要设置mysql的root账号,主要是密码。
首先,进入mysql:
mysql
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password by '你的root密码';
出现以下的提示就表示成功。
Query OK, 0 rows affected (0.01 sec)
退出mysql:
exit
测试一下root密码:
mysql -u root -p
然后就会提示要输入密码,如果输入正确,就能再次进入mysql。
注:到这里为止,只是设置了实验环境下的mysql安全配置,如果要用在正式的项目,还要进一步加强安全,通过“mysql_secure_installation”,笔者暂时先不管。
另外,使用以下命令也可以查询服务器的mysql运行状态:
service mysql status
● mysql.service - MySQL Community Server
Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled)
Active: active (running) since Fri 2022-06-24 14:21:04 CST; 2min 6s ago
Process: 757 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=0/SUCCESS)
Main PID: 938 (mysqld)
Status: "Server is operational"
Tasks: 38 (limit: 2264)
Memory: 420.5M
CGroup: /system.slice/mysql.service
└─938 /usr/sbin/mysqldJun 24 14:21:02 VM-8-15-ubuntu systemd[1]: Starting MySQL Community Server...
Jun 24 14:21:04 VM-8-15-ubuntu systemd[1]: Started MySQL Community Server.
3、打开mysql的远程访问限制
在服务器通过命令行,不方便操作mysql,尤其是一般都是会使用MySQL Workbench操作数据库,所以,最好打开云服务器的mysql远程访问限制。这样,就可以使用自己的电脑中Workbench直接操作云服务器中的mysql。
1)打开云服务器的3306端口,这是mysql默认的端口,要在云控制台中打开,才能让其它电脑访问进入服务器。
切换到云服务器控制台的防火墙,添加规则:
添加mysql的规则:(因为mysql3306是默认的,云平台也默认指定了端口,就不要随便修改了)
这里,也可以通过“限制来源”来指定只允许某些IP的电脑远程访问,学习用就不用设置了。
2)添加mysql的远程访问用户
因为mysql刚安装好后,全部的设置都只允许本地的操作,主要是在数据库【mysql】,表【user】中设置了。
如果想查看,可以进入mysql,执行以下脚本:
use mysql;
select user,host from user;
下面的结果,user表示用户名,host是允许访问的来源,可以看到全部都localhost,最重要是root用户,也是只允许本机。
接下来,就开始追加一个用于远程访问的用户。(因为root拥有最高权限,就不直接改root的host了,实际上,如果update root的host为%,也可以使root通过远程访问)
还是在mysql的模式中,执行以下脚本:(这是基于新版本mysql的添加方法)
--添加用户和密码,%表示允许所有IP远程访问,也可以指定IP
create user '用户名'@'%' identified by '密码'; --赋予这个用户全部权限,相当于仅次root
grant all privileges on *.* to '用户名'@'%' with grant option; --刷新权限
flush privileges;
成功后,再查一次user,就会有新的user和host。
这个时候,就设置完成了。用自己电脑的Workbench就可以远程连接了。
4、安装Nginx
更新源:
apt update
安装Nginx:
apt-get install -y nginx
查看nginx的版本:
nginx -v
nginx version: nginx/1.18.0 (Ubuntu)
到这里nginx就安装好了。
使用以下命令也可以查询服务器的nginx运行状态:
service nginx status
● nginx.service - A high performance web server and a reverse proxy server
Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
Active: active (running) since Fri 2022-06-24 15:27:04 CST; 3min 50s ago
Docs: man:nginx(8)
Main PID: 9260 (nginx)
Tasks: 3 (limit: 2264)
Memory: 6.8M
CGroup: /system.slice/nginx.service
├─9260 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
├─9261 nginx: worker process
└─9262 nginx: worker processJun 24 15:27:04 VM-8-15-ubuntu systemd[1]: Starting A high performance web server and a reverse proxy serve>
Jun 24 15:27:04 VM-8-15-ubuntu systemd[1]: Started A high performance web server and a reverse proxy server.
确认nginx正常运行后,可以直接访问云服务器的公网IP,如果看到以下页面就表示安装成功了。
5、安装Node.js
根据官方推荐的ubuntu安装方法,并且选择安装目前的长期支持版本,具体可见:
https://github.com/nodesource/distributions/blob/master/README.md
执行以下命令进行安装:
curl -fsSL https://deb.nodesource.com/setup_lts.x | sudo -E bash -
apt-get install -y nodejs
安装完成后,可以通过以下命令查看nodejs的版本:
node -v
v16.15.1
注:笔者这里发现查看不了,看了安装的过程日志,发现下载不成功,所以再执行了一次install。
另外,也确认一下npm的版本:
npm -v
8.11.0
npm是node的包管理器,在将来的开发中需要用到,不过是nodejs附带安装的,一般都没问题。
到这里nodejs就安装好了。
本次的安装记录就到这里为止,已经部署好了云服务器ubuntu的mysql、nginx、nodejs了。
有兴趣的朋友可以私信我交流,v:fanchengit
腾讯云服务器Ubuntu-配置mysql,nginx,nodejs的更多相关文章
- 在阿里云服务器上配置CentOS+Nginx+Python+Flask环境
在阿里云服务器上配置CentOS+Nginx+Python+Flask环境 项目运行环境 阿里云(单核CPU, 1G内存, Ubuntu 14.04 x64 带宽1Mbps), 具体购买和ssh连接阿 ...
- 腾讯云服务器 ubuntu 设置允许root用户登录
背景:最近购买了腾讯云服务器,使用了Ubuntu Server 14.04.1 LTS 64位操作系统,腾讯云主机ubuntu系统默认用户名为ubuntu,登录服务器时每一次都是以默认账号ubuntu ...
- 阿里云ECS服务器Ubuntu配置MySQL远程访问
root账户登录服务器Ubuntu16.04 apt-get update apt-get install mysql-server mysql-client; 安装时会让你设置root密码,输入2次 ...
- 腾讯云 服务器 ubuntu 16.04 python3 环境
积分 - 164 排名 - 183650 首先把腾讯云上的服务器,重装系统,选择64位ubuntu16.04,最低配也要用64位的…… 装好后,首先切换 python 版本: sudo update- ...
- 阿里云服务器ubuntu 配置
由于阿里云的导入自定义 ubuntu 镜像需要开通 OSS 快照是收费的(看着感觉不贵,但是也很麻烦),而且自己已配置好的镜像想导入需要转换格式,还存在不能使用的情况,所以麻烦点直接在阿里云原来的ub ...
- 阿里云腾讯云服务器ubuntu多域名配置
1.将域名A记录解析到服务器的公网 IP 地址,把www也添加A记录到公网ip 2.ubuntu系统修改hosts文件,hosts文件目录为/etc/hosts,可以用vim编辑 sudo vim ...
- Navicat连接远程主机(腾讯云服务器)的mysql失败,解决
赋予所有用户远程连接的权限,重启mysql即可连接成功: grant all privileges on . to 'root'@'%' identified by 'admin'; systemct ...
- 腾讯云服务器简单配置web项目
如图:目前域名备案工作完成,需要将主页展示出来, 域名解析就不讲了,超级简单, 如果不理解可以加群交流,这里主要讲一下通过Apache 开启服务(80端口)对项目进行展示 1. 首先安装Apache ...
- 腾讯云服务器部署 django项目整个流程
CentOS7下部署Django项目详细操作步骤 前记:购买腾讯云服务器,配置自选,当然新用户免费体验半个月,我选择的系统是centos7系统版本, 接下来我们来看整个配置项目流程. 部署是基于:ce ...
- 怎样将本地web数据库项目部署到腾讯云服务器上?
怎样将本地web数据库项目 部署到腾讯云服务器上? 1.本地计算机的工作: 1.1用eclipse或者myeclipse做好一个web项目,可以只做一个数据库的增删改查,本地部署到Tomcat服务器, ...
随机推荐
- 【FAQ】HarmonyOS SDK 闭源开放能力 —Push Kit
1.问题描述 升级到4.0.0.59版本后,通过pushService.getToken获取华为的token时报如下错误:Illegal application identity. 解决方案 Mate ...
- 【Insights直播】3D建模服务,快速构建高质量3D模型
2021年7月15日,HMS Core 6.0面向全球开发者正式上线.华为在HMS Core 6.0中,为开发者开放了一个全新的服务--3D建模服务(3D Modeling Kit),为应用开发者提供 ...
- mysql 重新整理——索引优化explain简单介绍 [八]
前言 做开发的我们晓得一个道理,就是说不是说你说这东西性能稳定就是性能稳定,你说发版本就发版本,这个是测试部门说了算的. 那么索引优化的关键也就是说一个我们来逐步调优,调优就要知道我们这条语句在mys ...
- js es6 标签模板还原字符串
前言 模板字符串的功能,它可以紧跟在一个函数名后面,该函数将被调用来处理这个模板字符串.这被称为"标签模板"功能(tagged template). 举个栗子: function ...
- MD5前端vue加密
Vue 前端md5加密用户注册时将加密后的密码发送给后端存储当登陆的时候,再将加密后的密码和数据库中加密的密码相匹配.npm: https://www.npmjs.com/package/crypto ...
- 【笔记】Cross Join&lag与lead函数
Oracle Cross Join交叉连接 语法 CROSS JOIN 指定第一个表的所有行与第二个表的所有行连接.如果 table1 中有"x"行,table2 中有" ...
- 力扣181(MySQL)- 超过经理收入的员工(简单)
题目: 表:Employee 编写一个SQL查询来查找收入比经理高的员工. 以 任意顺序 返回结果表. 查询结果格式如下所示. 示例 1: 解题思路: 一.[子查询] 先通过子查询找到当前员工的经理 ...
- 力扣561(java&python)-数组拆分(简单)
题目: 给定长度为 2n 的整数数组 nums ,你的任务是将这些数分成 n 对, 例如 (a1, b1), (a2, b2), ..., (an, bn) ,使得从 1 到 n 的 min(ai, ...
- 消息队列Kafka「检索组件」重磅上线!
简介:本文对消息队列 Kafka「检索组件」进行详细介绍,首先通过对消息队列使用过程中的痛点问题进行介绍,然后针对痛点问题提出相应的解决办法,并对关键技术技术进行解读,旨在帮助大家对消息队列 Kaf ...
- [GPT] swoole的协程和golang的协程有什么区别,哪个更好
Swoole 的协程和 Golang(Go 语言)的协程(Goroutine)在概念上都是为了实现轻量级的并发编程,但它们在具体实现.使用方式和性能特点上有所不同: 实现原理: Golang 协程(G ...