本篇会加入个人的所谓鱼式疯言

❤️❤️❤️鱼式疯言:❤️❤️❤️此疯言非彼疯言

而是理解过并总结出来通俗易懂的大白话,

小编会尽可能的在每个概念后插入鱼式疯言,帮助大家理解的.

🤭🤭🤭可能说的不是那么严谨.但小编初心是能让更多人能接受我们这个概念 !!!

在这里插入图片描述

引言

在当今数字化时代,搭建网站已成为一项重要技能。而要熟练搭建网站,Linux 指令是必不可少的工具。它们就像是打开网站建设大门的钥匙,能让你在数字世界中自由驰骋。让我们一起探索这些必学的 Linux 指令,开启精彩的网站搭建之旅吧!

目录

  1. Linux 的初识以及使用云服务器

  2. Linux的常用指令

  3. 部署项目

一. Linux 的初识以及使用云服务器

1. Linux 的初识

在这里插入图片描述

Linux 是和 window 并列的一种操作系统。

Linux是一种 自由和开发源 代码的 类 Unix 操作系统 ,具体 稳定性强安全性高多任务处理能力出色 的特点。

Linux创始人: Linus Torvalds(林纳斯·托瓦兹)

在这里插入图片描述

我们知道 操作系统 = 操作系统 + 应用程序

在这里插入图片描述

如上图:

上面这些图标就是 基于Linux 开发的应用程序,我们可以学习其中的一个 应用程序来操作Linux

而小编推荐的是如下图的 ubuntu 来操作我们 Linux系统

在这里插入图片描述

那我们该怎么使用 ubuntu 呢? 其实啊!

在我们的 云服务器 上大部分就基于 Linux 创建了它的实例, 我们只要操作云服务器在这些 实例 上进行 部署项目操作应用程序

下面就让小编带着小伙伴进行 云服务器的配置和使用教程 吧~

鱼式疯言

对于技术人员来说: 都会接触到 Linux , 所以Linux 可以是开发人员中 最强大的操作系统,没有之一


2. 购买云服务器

不知道小伙伴们是不是学生呢? 如果是大学生的话就可以免费白嫖阿里云的云服务器哦~

下面小编将详细的讲解阿里云服务器的 购买配置连接 , 以及最后 正常操作的一系列流程

<1>. 服务器的购买和配置

  • 领取 300优惠券
    在这里插入图片描述

  • 寻找最便宜的云服务器
    在这里插入图片描述

  • 选择 Ubuntu

在这里插入图片描述

  • 点击 按流量计费自定义密码

注意: 这里的 密码是连接密码 , 小伙伴们写的时候要记住哦~ 以免连接失败 ! ! !

最后 确定下单即可

  • 控制台 打开服务器

在这里插入图片描述

  • 确定公网ip

在这里插入图片描述

鱼式疯言

确定要自己的 公网ip ,我们讲通过 终端程序通过公网ip 和自己的账号和密码连接我们的云服务器

3. Xshell 连接服务器

Xshell 是什么? Xshell 就是一种用来连接服务器的终端, 相当于客户端的作用。 我们的云服务器的主机在千里之外的集群中,

而我们可以通过 Xshell 等这样的 应用程序的客户端来连接我们的服务器 ,对我们的服务器 操作部署项目和应用程序

下面小编将带着小伙伴们进行 下载安装 Xshell , 并对上面我们 刚配置的云服务器进行连接

<1>. 下载Xshell 流程

  1. 寻找 Xshell 官网 下载

在这里插入图片描述
在这里插入图片描述

  1. 点击 免费授权页面

在这里插入图片描述

  1. 下载默认安装 即可

在这里插入图片描述

  1. 安装成功页面

在这里插入图片描述

<2>. Xshell 建立连接

  • 点击 : 文件-新建
    在这里插入图片描述

  • 输入 自身公网ip

在这里插入图片描述

  • 输入密码建立连接

在这里插入图片描述

  • 连接成功画面

在这里插入图片描述

如上图, 如果是和小编一样是 ~# 结尾的, 就说明 连接成功
在这里插入图片描述

如上图,如果是 $ 结尾的, 说明还 没有正常连接上

如果小伙伴们需要断开连接怎么办 ? ? ?

请看 下方分解

  • 断开连接

在这里插入图片描述

  • 重新连接

在这里插入图片描述

这些都搭建好了, 下面,下面,下面就让小编带着小伙伴来酷炫的使用 命令 操作我们的 Linux 吧~


二. Linux的常用指令

Linux 是 目录树状结构

在这里插入图片描述

在这里插入图片描述

如上图: 当我们登录成功时, ~/java112/book 就表示当前用户的绝对路径: root/ java112/ book

鱼式疯言

  • / 表示 根目录

  • . 表示 当前目录

  • .. 表示 上一级目录

1. 操作目录

<1>. 查看当下目录下的子目录

命令ls
在这里插入图片描述

<2>. 查看当下目录下的详细子目录和文件

命令ls -l
在这里插入图片描述

<3>. 进行下一级目录

命令cd 子目录名/

在这里插入图片描述

鱼式疯言

  • 当输入 ja 时按下 tab 键,唯一的可自动生成目录名/文件名
    在这里插入图片描述
  • 输入到不唯一的文件名/ 目录 不过会有提示
    在这里插入图片描述

<4>. 查看当前目录

命令pwd

在这里插入图片描述

鱼式疯言

快捷键

<5>. 返回上一级目录

命令cd ../

在这里插入图片描述
如果是 返回多级目录 的话:

在这里插入图片描述

在这里插入图片描述

需要注意的是, cd 只能进入 下一级目录 , 而 不能进入文件

<6>. 创建目录

命令: mkdir 目录名
在这里插入图片描述

<7>. 删除目录

命令rm -r 目录名

在这里插入图片描述

<8>. 复制目录/文件

命令 : cp [-r] 源目录名/源文件名 目标目录名/目标文件名

文件 -> 文件
在这里插入图片描述

文件 -> 文件
在这里插入图片描述

目录 -> 目录

在这里插入图片描述

鱼式疯言

注意事项:

  1. 文件可以不存在会自动创建并且填充 , 但是目录不存在就会报错哦~
  1. 目录 拷贝到另外一个目录下 , 需要 在 cp 的后面加上 -r , 否则就会报错。

<9>. 移动文件/目录

命令 : mv 源目录名/源文件名 目标目录名/目标文件名

在这里插入图片描述

对于 存在的的目标目录名 , 会进行 移动源文件/源目录的操作

但是对于 不存在的目标目录名 , 会进行 重命名操作

在这里插入图片描述

<10>. 清空屏幕

命令clear

在这里插入图片描述

在这里插入图片描述

鱼式疯言

补充说明

  • cpcopy 的缩写, mvmove 的缩写
  • 设置 配色方案

在这里插入图片描述

小编选择的配置如下

在这里插入图片描述

颜色区分

在这里插入图片描述

一般而言: 绿色目录红色压缩包黑色 一般为 普通文件

  • 设置复制粘贴快捷键

在这里插入图片描述

在这里插入图片描述

设置完这些, 小伙伴们可以自己去体验一下咯 ~ ~ ~

2. 文件操作

<1>. 创建文件

命令touch 文件名

在这里插入图片描述

<2>. 上传文件

命令: rz 选择指定文件
在这里插入图片描述

在这里插入图片描述

<3>. 下载文件

命令: sz 文件名

在这里插入图片描述

在这里插入图片描述

<4>. 查看文件内容

  • 查看全文文件

命令: cat 文件名

在这里插入图片描述

  • 查看文件头信息

命令: head [-n] 文件名

在这里插入图片描述

-n指定n行 , 未指定 -n 默认为前十行

  • 查看文件尾信息

命令: tail [-n] 文件名
在这里插入图片描述

-n指定n行 , 未指定 -n 默认为尾部十行

  • 文件尾循环读入

命令: tail -f 文件名

在这里插入图片描述

crtl + c 表示 退出

鱼式疯言

总结概括:

常见退出的命令套路:

  • ctrl + c

  • exit

  • :q

  • :q!

小伙伴们当使用 一个命令不能退出 时,可以都尝试一下以上的这些全部 退出命令的套路

<5>. 编辑文件

  • 命令: vi / vim 文件名

    在这里插入图片描述

  • 按下 i/ 任意字母键 开始编辑
    在这里插入图片描述

  • 编辑结束退出按下 ESC 键

在这里插入图片描述

  • 保存并退出的命令: : wq

在这里插入图片描述

在这里插入图片描述

鱼式疯言

分解说明

  • q 表示退出

  • w 表示保持

  • ! 表示强制

故: :wq 表示 保存退出 , :wq! 表示 强制保存退出 等… 这些都是以上 三个字符之间的相互组合

<6>. 查找指定文本内容

  • 命令: grep 查找字符串 文件名

    在这里插入图片描述

<7>. 删除文件

命令: rm 文件名

在这里插入图片描述

3. 其他操作

<1>. 查看进程

  • 查看所有进程
    命令: ps aux / -ef
    在这里插入图片描述

  • 管道查找目标进程

命令: ps aux / -ef | grep 进程名/进程ID

在这里插入图片描述

管道: | 用这个或字符表示 把前面那个命令当成后面那个命令的基础来执行 ,也就相当于 在前面的基础上进行了查询

<2>. 查看网络状态

网络: netstat -anp | grep 进程名/ 端口号

在这里插入图片描述

鱼式疯言

  • a 表示显示所有的主机

  • n 表示显示端口号

  • p 表示显示进程

故: anp 就表示所有主机的 进程和端口号

三. 部署项目

1. 更新apt 数据包

  • 命令: sudo apt-get update

在这里插入图片描述

apt 是高级管理软件包的一种工具, 可以 方便软件包的更新,删除,安装操作

2. 安装openjdk

  • 查看openjdk
    命令: apt list | grep 软件包名
    在这里插入图片描述

  • 安装jdk
    命令: sudo apt install 软件包名

在这里插入图片描述
一路点 Y
在这里插入图片描述

鱼式疯言

JDK 分为 : 有版权需要付费OracleJDK开源免费OpenJDK

3. 安装数据库

  • 查找mysql

命令: apt list |grep "mysql-server"

在这里插入图片描述

  • 安装mysql

命令: sudo apt install mysql-server

在这里插入图片描述

在这里插入图片描述

  • 查看mysql 状态

命令: sudo systemctl status mysql

  • 一路 Y 即可
    在这里插入图片描述

4. mysql 安全设置

  • 安全设置
    命令: sudo mysql_secure_installation

    一路 y 即可
    在这里插入图片描述

  • 输入 2 确定
    在这里插入图片描述

    一路 y 即可

在这里插入图片描述

5. 设置mysql 密码

  • 连接 mysql

命令: sudo mysql
在这里插入图片描述

  • 设置密码

    命令: ALTER USER ‘root’@‘localhost’ IDENTIFIED WITH mysql_native_password BY 密码

    在这里插入图片描述

6. 数据准备

准备好项目需要的 数据资源

  • 重新连接mysql

命令: ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'zcy@123456GO'

在这里插入图片描述

  • 插入数据
-- 建表SQL
create database if not exists java_blog_spring charset utf8mb4;

use java_blog_spring;
-- 用户表
DROP TABLE IF EXISTS java_blog_spring.user_info;
CREATE TABLE java_blog_spring.user_info(
                                           `id` INT NOT NULL AUTO_INCREMENT,
                                           `user_name` VARCHAR ( 128 ) NOT NULL,
                                           `password` VARCHAR ( 128 ) NOT NULL,
                                           `safe_password` VARCHAR ( 128 ) NOT NULL ,
                                           `github_url` VARCHAR ( 128 ) NULL   DEFAULT 'https://blog.csdn.net/mgzdwm?type=blog',
                                           `picture` VARCHAR(100) NULL DEFAULT 'pic/joke.jpg',
                                           `delete_flag` TINYINT ( 4 ) NULL DEFAULT 0,
                                           `create_time` DATETIME DEFAULT now(),
                                           `update_time` DATETIME DEFAULT now() ON UPDATE now(),
                                           PRIMARY KEY ( id ),
                                           UNIQUE INDEX user_name_UNIQUE ( user_name ASC )) ENGINE = INNODB DEFAULT CHARACTER
    SET = utf8mb4 COMMENT = '用户表';

-- 博客表

drop table if exists java_blog_spring.blog_info;
CREATE TABLE java_blog_spring.blog_info (
                                            `id` INT NOT NULL AUTO_INCREMENT,
                                            `title` VARCHAR(200) NULL,
                                            `content` TEXT NULL,
                                            `user_id` INT(11) NULL,
                                            `delete_flag` TINYINT(4) NULL DEFAULT 0,
                                            `create_time` DATETIME DEFAULT now(),
                                            `update_time` DATETIME DEFAULT now() ON UPDATE now(),
                                            PRIMARY KEY (id))
    ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COMMENT = '博客表';

-- 新增用户信息
insert into java_blog_spring.user_info (user_name, password, safe_password,picture,github_url)values('张三','123456','f9faff19a2fc4dc1a458a519dd124e2347fac6dd554c0163b43a8c9c2e7d929c', 'pic/doge.jpg','https://gitee.com/zcy456/test_java');
insert into java_blog_spring.user_info (user_name, password,safe_password,picture,github_url)values('李四','123456', 'f9faff19a2fc4dc1a458a519dd124e2347fac6dd554c0163b43a8c9c2e7d929c' , 'pic/ku.jpg','https://gitee.com/zcy456/springdemo');
insert into java_blog_spring.user_info (user_name, password,safe_password,picture,github_url)values('江写题','5201314','54925c871240423eb1e9e9293ec7f1229983cd0b451a356dd4f4c3869aa1be5c','pic/pig.jpg','https://gitee.com/zcy456/springdemo');
insert into java_blog_spring.user_info (user_name, password,safe_password,picture,github_url)values('周吃鱼','5201314','54925c871240423eb1e9e9293ec7f1229983cd0b451a356dd4f4c3869aa1be5c','pic/man.jpg','https://gitee.com/zcy456/test_java');

insert into java_blog_spring.blog_info (title,content,user_id) values('第一篇博客','111我是博客正文我是博客正文我是博客正文',1);
insert into java_blog_spring.blog_info (title,content,user_id) values('第二篇博客','222我是博客正文我是博客正文我是博客正文',2);
insert into java_blog_spring.blog_info (title,content,user_id) values('第三篇博客','333我是博客正文我是博客正文我是博客正文',3);
insert into java_blog_spring.blog_info (title,content,user_id) values('第四篇博客','444我是博客正文我是博客正文我是博客正文',4);

在这里插入图片描述

7. 修改项目mysql密码和mysql密码统一

在这里插入图片描述

8. 打包项目jar包

  • 关闭测试功能并点击 packagejar包
    在这里插入图片描述

  • 打包jar 包
    在这里插入图片描述

9. 上传 jar 包并运行

  • 退出 mysql

    命令exit

    在这里插入图片描述

  • 上传 jar 包

方式一: 直接拖

在这里插入图片描述

idea 上选择 jar 包 鼠标摁住往 Xshell 拖动即可。

方式二:使用命令

命令rz

在这里插入图片描述
在这里插入图片描述

  • 太长了 重命名一下

在这里插入图片描述

  • 运行java包
    命令: java -jar jar包名

在这里插入图片描述

程序正常运行

11. 添加端口号8080(防火墙 / 安全组添加)

  • 打开安全组
    在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

10. 访问测试

  • 使用: 公网ip + 端口号8080 + URL 路径 访问

在这里插入图片描述

退出程序

命令: ctrl + c

在这里插入图片描述

11. 后台运行

命令: nohup java -jar jar包名 &

在这里插入图片描述

使用上面命令确定后, 出现了 下面这串数字就说明运行成功了, 10382进程号

  • 循环查看运行日志

命令: tail -f nohup out

在这里插入图片描述

12. 结束后台运行,杀死进程

寻找进程号杀死进程

方式一: 直接寻找 java相关的进程号然后杀死对应进程

在这里插入图片描述
方式二: 通过端口号查找java进程号来杀死

在这里插入图片描述

  • 杀死进程

在这里插入图片描述

出现上面 exit 就说明 进程 以及被杀死了 。

鱼式疯言

异常情况处理

如果对于 mysql 安装失败或者 mysql 密码错误的openJDK安装失败 的小伙伴, 可以 卸载重装 哦~

  • 卸载Open JDK
  1. 检查安装的是哪个OpenJDK dpkg --list | grep -i jdk

  2. 移除 openjdk包: apt-get purge openjdk

  3. 卸载 OpenJDK 相关包: apt-get purge icedtea-* openjdk-*

  4. 检查所有 OpenJDK包是否都已卸载完毕:
    dpkg --list | grep -i jdk

  • 卸载 mysql
  1. 停止mysql sudo systemctl stop mysql

  2. 卸载mysql sudo apt-get remove --purge mysql-server mysql-client mysql-common

  3. 删除 MySQL 配置文件和数据 sudo rm -rf /etc/mysql /var/lib/mysql

  4. 清理残留文件和目录 sudo apt-get autoremove sudo apt-get autoclean

  5. 验证卸载结果 mysql --version

总结

  • Linux 的初识以及使用云服务器: 了解 Linux 操作系统稳定性强安全性高多任务处理能力出色 的和 window 并行的 操作系统

  • Linux的常用指令: 本篇中,介绍了平常 工作中常用的命令 , 通过命令主要围绕着对 目录文件进程,以及 网络 四个方面进行的读写操作, 这些基础的常见的命名是小伙伴必须要掌握的哦~

  • 部署项目: 跟着小编复制对应的命令即可, 只要熟悉大方向: 安装JDK和mysql设置mysql数据准备打包jar上传jar并运行测试程序杀死进程。

如果觉得小编写的还不错的咱可支持 三连 下 (定有回访哦) , 不妥当的咱请评论区 指正

希望我的文章能给各位宝子们带来哪怕一点点的收获就是 小编创作 的最大 动力 💖 💖 💖

在这里插入图片描述

Logo

欢迎加入西安开发者社区!我们致力于为西安地区的开发者提供学习、合作和成长的机会。参与我们的活动,与专家分享最新技术趋势,解决挑战,探索创新。加入我们,共同打造技术社区!

更多推荐