linux基本操作

linux

1.0 基本网络配置

VMware三种网络配置方式

  1. Bridged桥接模式(推荐):
    VMWare虚拟出来的操作系统就像是局域网中的一台独立的主机,它可以访问网内任何一台机器,你需要手工为虚拟系统配置IP地址、子网掩码,而且还要和宿主机器处于同一网段,这样虚拟系统才能和宿主机器进行通信,虚拟系统和宿主机器的关系,就像连接在同一个Hub上的两台电脑。

  2. NAT网络地址转换模式:
    虚拟系统借助NAT的功能,通过宿主机所在的网络来访问公网。在这种模式下宿主机成为双网卡主机,同时参与现有的宿主局域网和新建的虚拟局域网,但由于加设了一个虚拟的NAT服务器,使得虚拟局域网内的虚拟机在对外访问时,使用的则是宿主机的IP地址,这样从外部网络来看,只能看到宿主机,完全看不到新建的虚拟局域网。

  3. Host-only主机模式:
    新建了一个由所有虚拟机与宿主机所构成的局域网,但该局域网与宿主机本身所处的现有局域网是相互独立的,如果不做额外路由设置,这两个局域网之间不会连通,因此新建的局域网可以认为是一个单独从属于当前宿主机的私有网络,其成员为当前宿主机和相关的所有虚拟机。

桥接模式网络配置

  1. 配置ip地址等信息
    在 /etc/sysconfig/network-scripts/ifcfg-eno16777736文件里做如下配置
TYPE=Ethernet # 网络类型为以太网
BOOTPROTO=static # 手动分配ip
DEVICE=eno16777736 # 网卡设备名,设备名一定要跟文件名一致
ONBOOT=yes # 该网卡是否随网络服务启动
IPADDR=192.168.0.60 # 该网卡ip地址
NETMASK=255.255.255.0 # 子网掩码
GATEWAY=192.168.0.1 # 网关
DNS1=8.8.8.8 # DNS,8.8.8.8为Google提供的免费DNS服务器的IP地址
  1. 配置网络工作
    在/etc/sysconfig/network文件里增加如下配置
NETWORKING=yes # 网络是否工作,此处一定不能为no
  1. 配置公共DNS服务(可选)
    在/etc/resolv.conf文件里增加如下配置
nameserver 8.8.8.8
  1. 关闭防火墙
#systemctl stop firewalld # 临时关闭防火墙
#systemctl disable firewalld # 禁止开机启动
  1. 重启网络服务
#service network restart
  1. 局域网网络代理

为系统设置代理

临时
export http_proxy=http://ip:port
export https_proxy=http://ip:port

永久
vim /etc/profile
http_proxy=http://127.0.0.1:9666 #代理程序地址
https_proxy=http://127.0.0.1:9666
ftp_proxy=http://127.0.0.1:9666
# 访问局域网地址(192.168.20.0/24网段)时不使用代理,可以用逗号分隔多个地址
no_proxy=192.168.10.0 不代理
export http_proxy
export ftp_proxy
export https_proxy

无需代理的主机或域名:
*.aiezu.com,10.*.*.*,192.168.*.*
可以使用通配符*;           *.local,localhost,127.0.0.1
多个时使用","号分隔;

# 更新一下环境文件
source /etc/profile

为yum配置代理

/etc/yum.conf后面添加以下内容:
proxy=http://proxy.com:8080/

proxy=http://proxy.com:8080/
proxy_username=代理服务器用户名
proxy_password=代理服务器密码


source /etc/yum.conf

为wget代理设置

编辑文件为:/etc/wgetrc

http_proxy=http://proxy.com:8080/
https_proxy=http://proxy.com:8080/

source /etc/wgetrc

2.0 Linux文件系统概览

img

常见目录说明:

/bin: 存放二进制可执行文件(ls,cat,mkdir等),常用命令一般都在这里;

/etc: 存放系统管理和配置文件;

/home: 存放所有用户文件的根目录,是用户主目录的基点,比如用户user的主目录就是/home/user,可以用~user表示;

/usr : 用于存放系统应用程序;

/opt: 额外安装的可选应用程序包所放置的位置。一般情况下,我们可以把tomcat等都安装到这里;

/proc: 虚拟文件系统目录,是系统内存的映射。可直接访问这个目录来获取系统信息;

/root: 超级用户(系统管理员)的主目录(特权阶级o);

/sbin: 存放二进制可执行文件,只有root才能访问。这里存放的是系统管理员使用的系统级别的管理命令和程序。如ifconfig等;

/dev: 用于存放设备文件;

/mnt: 系统管理员安装临时文件系统的安装点,系统提供这个目录是让用户临时挂载其他的文件系统;

/boot: 存放用于系统引导时使用的各种文件;

/lib : 存放着和系统运行相关的库文件 ;

/tmp: 用于存放各种临时文件,是公用的临时文件存储点;

/var: 用于存放运行时需要改变数据的文件,也是某些大文件的溢出区,比方说各种服务的日志文件(系统启动日志等。)等;

/lost+found: 这个目录平时是空的,系统非正常关机而留下“无家可归”的文件(windows下叫什么.chk)就在这里。

3.0 Linux基本命令

Linux命令用法一般用man命令可以查看其帮助信息

中文Linux命令帮助大全:https://www.linuxcool.com/

目录

# 切换
cd usr: 切换到该目录下usr目录
cd ..(或cd../): 切换到上一层目录
cd /: 切换到系统根目录
cd ~: 切换到用户主目录
cd -: 切换到上一个所在目录
# 增删改查
mkdir 目录名称: 增加目录
ls或者ll(ll是ls -l的缩写,ll命令以看到该目录下的所有目录和文件的详细信息):查看目录信息
find 目录 参数: 寻找目录(查)
	列出当前目录及子目录下所有文件和文件夹: find .
 	在/home目录下查找以.txt结尾的文件名:find /home -name ".txt"
	同上,但忽略大小写: find /home -iname ".txt"
	当前目录及子目录下查找所有以.txt和.pdf结尾的文件:find . \( -name ".txt" -o -name ".pdf" \)或find . -name ".txt" -o -name ".pdf"
	
mv 目录名称 新目录名称: 修改目录的名称(改)
mv 目录名称 目录的新位置: 移动目录的位置---剪切(改)
cp -r 目录名称 目录拷贝的目标位置: 拷贝目录(改),-r代表递归拷贝
rm [-rf] 目录: 删除目录(删)

文件

# 文件的操作命令(增删改查)
touch 文件名称: 文件的创建(增)
cat /more/less/tail 文件名称 文件的查看(查)
	cat: 只能显示最后一屏内容
	more: 可以显示百分比,回车可以向下一行, 空格可以向下一页,q可以退出查看
	less: 可以使用键盘上的PgUp和PgDn向上 和向下翻页,q结束查看
	head -10 : 查看文件的前10行,Ctrl+C结束
	tail -10 : 查看文件的后10行,Ctrl+C结束
	tail -f catalina-2016-11-11.log 监控 文 件的变化
	
## vim命令
#移动光标
vim 可以使用小写英文字母 h j k l 分别控制光标左 下 上 右移动,也可以使用箭头
Ctrl+b 屏幕往后移动一页
Ctrl+f 屏幕往前移动一页
Ctrl+u 屏幕往后移动半页
Ctrl+d 屏幕往前移动半页
Shift+g == G 移动到文章的最后
Shift+4 == $ 移动到光标所在行的行尾
Shift+6 == ^ 移动到光标所在行的行首
w 光标跳到下个字的开头
e 光标跳到下个字的字尾
b 光标回到上个字的开头
gg 进入到文本的开始

# 删除文字
x 每按一次删除光标所在位置的一个字符
#x 栗子:6x 删除光标所在位置的"后面"(包含自己在内)6个字符
Shift+x == X 每按一次,删除光标所在位置的前一个字符
Shift+#x == #X 栗子 20X 删除光标所在位置的前面20个字符
dd 删除光标所在行
#dd 栗子 6dd 从光标所在行开始删除6行

# 复制
yw 将光标所在之处到字尾的字符复制到缓冲区中
#yw 栗子 6yw 复制6个字符到缓冲区
yy 复制光标所在行到缓冲区
#yy 栗子 6yy 拷贝从光标所在的该行"往下数"6行文字
p 将缓冲区内的字符贴到光标所在位置
#所有与y有关的复制命令都必须与p配合才能完成复制粘贴功能

# 替换
r 替换光标所在处的字符
R 替换光标所到之处的字符,知道按下Esc键为止.

# 撤销上一次的操作
u 回到上一个操作,按动多次'u'可以执行多次回复

# 更改
cw 更改光标所在处的字到字尾处
c#w 栗子 c3w 表示更改三个字

# 跳至指定行
Ctrl+g 列出光标所在行的行号
#G 栗子 15G 表示移动光标到文章的第15行行首

# 删除
rm -rf 文件: 删除文件(删)

解压缩

Linux中的打包文件一般是以.tar结尾的,压缩的文件一般是以.gz结尾的。

而一般情况下打包和压缩是一起进行的,打包并压缩后的文件的后缀名一般.tar.gz。

压缩

tar -zcvf 打包压缩后的文件名 要打包压缩的文件 其中:

tar -zcvf test.tar.gz /test/

z:调用gzip压缩命令进行压缩

c:打包文件

v:显示运行过程

f:指定文件名

解压

命令:tar [-xvf] 压缩文件

其中:x:代表解压

tar -xvf test.tar.gz

tar -xvf xxx.tar.gz -C /usr(- C代表指定解压的位置)

权限命令

每个文件都拥有特定的权限、所属用户和所属组。权限是操作系统用来限制资源访问的机制,在Linux中权限一般分为读(readable)、写(writable)和执行(excutable),分为三组。分别对应文件的属主(owner),属组(group)和其他用户(other),通过这样的机制来限制哪些用户、哪些组可以对特定的文件进行什么样的操作。

第一列的内容的信息解释如下:

img

文件的类型:

d: 代表目录

-: 代表文件

l: 代表链接(可以认为是window中的快捷方式)

Linux中权限分为以下几种

r:代表权限是可读,r也可以用数字4表示

w:代表权限是可写,w也可以用数字2表示

x:代表权限是可执行,x也可以用数字1表示

文件和目录权限的区别:

对文件和目录而言,读写执行表示不同的意义。

对于文件:

权限名称 可执行操作
r 可以使用cat查看文件的内容
w 可以修改文件的内容
x 可以将其运行为二进制文件

对于目录:

权限名称 可执行操作
r 可以查看目录下列表
w 可以创建和删除目录下文件
x 可以使用cd进入目录

在linux中的每个用户必须属于一个组,不能独立于组外。在linux中每个文件有所有者、所在组、其它组的概念。

所有者

一般为文件的创建者,谁创建了该文件,就天然的成为该文件的所有者,用ls ‐l命令可以看到文件的所有者 也可以使用chown 用户名 文件名来修改文件的所有者 。

文件所在组

当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组 用ls ‐l命令可以看到文件的所有组 也可以使用chgrp 组名 文件名来修改文件所在的组。

其它组

除开文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组

# 修改文件/目录的权限
chmod u=rwx,g=rw,o=r aaa.txt
# 还可以使用数字表示:
chmod 764 aaa.txt

开机自启

1. 新建一个脚本zookeeper

2. 为新建的脚本zookeeper添加可执行权限,命令是:chmod +x zookeeper

3. 把zookeeper这个脚本添加到开机启动项里面,命令是:chkconfig --add zookeeper

4. 如果想看看是否添加成功,命令是:chkconfig --list

防火墙操作

# 查看防火墙
systemctl status firewalld
# 查看防火墙是否开机自启
systemctl is-enabled
# 查看所有开放端口
netstat -aptn
# 开启防火墙
systemctl start firewalld.service
# 关闭防火墙 
systemctl stop firewalld.service
# 重启防火墙
systemctl restart firewalld.service
# 开机自启防火墙
systemctl enable firewalld.service

# 临时打开端口(当开放端口设置完成后必须要重启,否则不生效)
firewall-cmd --zone=public --add-port=80/tcp
# 永久打开端口 (当开放端口设置完成后必须要重启,否则不生效)
firewall-cmd --permanent --zone=public --add-port=80/tcp

Linux 用户管理

useradd 选项 用户名:添加用户账号
userdel 选项 用户名:删除用户帐号
usermod 选项 用户名:修改帐号
passwd 用户名:更改或创建用户的密码
passwd -S 用户名 :显示用户账号密码信息
passwd -d 用户名: 清除用户密码
su - 用户名:切换登录用户

useradd指令所建立的帐号,实际上是保存在/etc/passwd文本文件中。该文件内容的解释:

用户名:密码:用户id:组id:用户说明:用户的主目录:用户使用的shell环境(默认为bash)

Linux用户组管理

每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。/etc/group

groupadd 选项 用户组 :增加一个新的用户组
groupdel 用户组:要删除一个已有的用户组
groupmod 选项 用户组 : 修改用户组的属性

其他常用命令

pwd: 显示当前所在位置路径

grep 要搜索的字符串 要搜索的文件 --color: 搜索命令,--color代表高亮显示

ps -ef/ps aux: 这两个命令都是查看当前系统正在运行进程,两者的区别是展示格式不同。如果想要查看特定的进程可以使用这样的格式:ps aux|grep redis (查看包括redis字符串的进程)

kill -9 进程的pid: 杀死进程(-9 表示强制终止。)

shutdown -h now: 指定现在立即关机;

shutdown +5 指定5分钟后关机

reboot: reboot: 重开机

reboot -w: 做个重开机的模拟(只有纪录并不会真的重开机)

网络通信命令

ifconfig # 查看当前系统的网卡信息
ping # 查看与某台机器的连接情况
netstat # 查看当前系统的端口
	-an 所有的连接和端口
	-tuln 查看正在监听TCP(t)和UDP(u)的端口

创建链接文件

软链接特点:权限是所有人都可以访问,并且软连接文件指向源文件,和快捷方式一样

硬链接:类似copy,硬链接大小和源文件一样,并且是同步更新的

ln -s [源文件] [目标文件]  # (硬链接不需-s选项)创建软链接文件

设置全局变量

1 vim /etc/profile

JAVA_HOME=/usr/local/jdk1.8.0_181
CLASSPATH=$JAVA_HOME/lib/
PATH=$PATH:$JAVA_HOME/bin
export PATH JAVA_HOME CLASSPATH

2 source /etc/profile

用户变量

vim ~/.bash_profile 
source ~/.bash_profile 
posted @ 2023-01-19 14:51  浮沉丶随心  阅读(27)  评论(0编辑  收藏  举报