Linux系统目录结构:
逻辑上所有的目录只有一个顶点/(根),所有的目录的起点。
根下面类似一个倒挂的树一样的层次结构,只有一颗树(区别window,每个盘符都是一棵树)tree -L 1(显示层数) /
linux的目录结构也是有规律的,而且也是按照类别组织的。
应用程序 /usr/bin
数据文件 帮助/usr/share配置文件 /etc/启动命令 /etc/init.d1).Linux的所有目录结构是一个有层次的倒挂着的树形目录结构
2).根"/"是所有目录的顶点3).目录结构和分区设备是没有关系的,也就是不同的目录可以跨越不同的磁盘设备4).所有的目录都是按照一定的类别有规律的组织和命名的。相对路径和绝对路径
绝对路径:从根开始就是绝对路径 cd /data/相对路径:不从根开始的路径 cd ../关机与重启命令
halt 关机reboot 重启shutdown -r now(时间) 重启shutdown -h now 关机
linux的一些目录结构分析:
/dev/ 设备目录/etc/ 文件以及服务启动的目录/proc/ 显示内核及进程信息虚拟文件系统/tmp 临时文件目录/home 普通用户家目录/var/ 变化目录,一般是日志文件的目录 /usr/ 用户程序及数据,帮助文件等目录/bin 和 /sbin 和 /usr/sbin 用户命令的目录
重要的一些子目录说明:
1.网卡地址:etc/sysconfig/network-scripts/ifcfg-eth0/etc/init.d/network restart 重启网卡(所有网卡)ifdown eth0 && ifup eth0 (只对eth0)通过setup可以设置网络配置
2.设置Linux本地的客户端DNS的文件--DNS可以实现域名和IP的解析
/etc/resolv.conf
3.设置用户IP和名字(或域名)的对应解析表
/etc/hosts
4.修改机器名及网卡启动,网关等配置
/etc/sysconfig/network
5.记录开机要mount的文件系统的一个文件
/etc/fstab
6.存放开机自启动程序命令的文件(chkconfig只能管理yum、rpm安装程序的启动服务)
/etc/rc.local
7.设定系统启动时,init进程将系统设置成什么样的runlevel及加载相关的启动文件设置。linux开机启动流程。
/etc/inittab
8.存放系统或服务器启动的脚本
/etc/init.d
9.系统全局环境变量配置路径
/etc/profile#查看系统版本cat /etc/issue#查看版本信息#隐藏系统版本#>/etc/issue或者cat /dev/null >/etc/issue
锁定关键系统文件
上锁:chattr +i /etc/passwd /etc/shadow/ /etc/group /etc/gshadow /etc/inittab解锁:chattr -i /etc/passwd /etc/shadow/ /etc/group /etc/gshadow /etc/inittab
查看内容是否加锁:
lsattr(查看文件属性) /etc/passwdchattr(修改文件属性)SELinux
关闭SElinuxvim /etc/selinux/config更改:SELINUX=enforcing为:SELINUX=disabled
或者使用命令:
sed -i s#SELINUX=enforcing#SELINUX=disabled#g /etc/selinux/config
修改之后查看:
grep "disabled" /etc/selinux/config
执行命令:
setenforce 0(生效需要重启,但是Linux一般不重启,所有先临时更改setenforce 0,启后永久更改)
Linux启动有7种启动模式:
查看当前系统运行级别runlevel
编辑启动文件
vi /etc/inittab(配置文件)
不同运行级别模式之间的切换
init 0(关机)/1/2/3(默认命令模式)/4/5(桌面模式)/6
精简开机系统启动的服务为:
1).setup->systerm service2).ntsysv3).脚本一键完成处理chkconfig查看设置开机自动启动软件的命令类似与windows下的msconfig命令
chkconfig --list |grep "3:on"
如果是中文,执行命令:
LANG=en
更改sshd远程连接配置
cp /etc/ssh/sshd_config /etc/ssh/sshd_config.ori 对源文件进行备份vi /etc/ssh/sshd_config 编辑sshd_config更改内容:port 52113 ssh连接默认的端口为22,更改更安全PermitRootLogin no root用户黑客都知道,禁止它远程登录,但可以本地登录PermitEmptyPasswords no 禁止空密码登录UseDNS no 不使用DNS
重启生效
/etc/init.d/sshd restart
关闭防火墙
/etc/init.d/iptables stop
查看网络状态
netstat -an或-lntup | grep sshlsof -i port(52113) 有结果表示服务已开启52113为更改后的sshd端口
更改字符集
vi /etc/sysconfig/il8n更改为:LANG="zh_CN.GB18030"SYSFONT="latarcyrheb-sun 16"source /etc/sysconfig/il8n 使更改生效echo $LANG 查看字符集
时间同步
Linux系统的时间同步方法--ntp服务时间软件which ntpdate/usr/bin/ntpdate
执行如下命令:
/usr/sbin/ntpdate time.nist.gov 临时设置同步#定时任务echo '#time synv by user at 2016-1-30'>>/var/spool/cron/rootecho '*/5 * * * */'usr/sbin/ntpdate time.nist.gov>/dev/null 2>&1'>>/var/spool/cron/rootcrontab -l
额外学习:linux优化笔记整理
基础优化回顾总结:
1).不用root,添加普通用户,通过sudo授权管理;2).更改默认的远程连接SSH服务端口及禁止root用户远程连接;3).定时自动更新服务器时间4).配置yum更新源,从国内更新源下载安装rmp包5).关闭selinux及iptables(iptables工作场景如果有wap ip一般要打开,高并发除外)6).调整文件描述符的数量,进程及文件的打开都会消耗文件描述符7).定时自动清理/var/spool/clientmquene/目录垃圾文件,放在inodes节点被占满8).精简开机自启动服务(crond,sshd,network,rsyslog)9).Linux内核参数优化(etc/sysctl.conf,执行sysctl -p生效)10).更改字符集,支持中文,但建议还是用英文字符集,放在乱码问题11).锁定关键系统文件chattr +i /etc/passwd /etc/shadow/ /etc/group /etc/gshadow /etc/inittab处理以上内容,把chattr改名test,会相对更安全。12).清空/etc/issue,去除系统及内核版本登录前的屏幕显示。cat 显示内容输出tac 反转内容输出tail -f(跟踪文件结尾变化) a.txt