CentOS

来自DeerGrove Wiki
Aker讨论 | 贡献2019年9月17日 (二) 08:31的版本
跳转至: 导航搜索

基于CentOS7.4的服务器搭建笔记,记录起始于:2019/9/10 @ 浙江嘉兴

GUI切换Terminal

  1. Ctrl+alt+F1~F6 从图形登陆界面切换到dos界面;
  2. 界面切换到命令行界面输入 init 3 命令;
  3. 命令行界面切换到图形界面输入 init 5 命令;

centos下修改文件后如何保存退出

保存命令,按ESC键 跳到命令模式,然后:

  1.  :w 保存文件但不退出vi
  2.  :w file 将修改另外保存到file中,不退出vi
  3.  :w! 强制保存,不推出vi
  4.  :wq 保存文件并退出vi
  5.  :wq! 强制保存文件,并退出vi
  6.  :q 不保存文件,退出vi
  7.  :q! 不保存文件,强制退出vi
  8.  :e! 放弃所有修改,从上次保存文件开始再编辑

yum clean all大坑解决

  • 在Centos7系统中执行yum clean all 之后,发现yum的其他执行都报错了;要解决,关键在这里:
  1. 把/var/cache/yum/ 下面的文件删除了
  2. 接下来,如果执行yum repolist all,结果为0;执行yum list正常的话,那就是/etc/yum.repos.d/*.repo 这货有问题啦,解决这货的问题
  3. 执行 yum makecache 然后再执行yum update
  4. OK
  • yum仓库的命令:
  1. yum repolist 列出yum仓库
  2. yum clean all 清理yum 缓存
  3. yum makecache 缓存yum仓库

PHP extension冲突问题(如:php70w 与 php-common < 7.0的冲突)

一般情况下是发生在PHP升级情况下,php核心和扩展多版本共存,版本发生冲突情况下的警告,可能导致php环境运行异常

  • PHP7极大地改进了性能,在一些WordPress基准测试当中,性能可以达到PHP 5.6的3倍。
  • 使用Yum安装PHP有两个源可以选择,一个是webtatic提供的,也就是php70w,那个w指得就是webtatic,另一个可以使用remi源。
  1. yum install epel-release
  2. rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
  3. yum update
  4. yum list | grep php # 罗列yum源可安装包
  • 另一种做法,移除php-common
  1. yum remove php-common # 再次执行
  2. yum -y install php70w-devel
  • 使用yum install命令安装,如果直接yum install php,安装的PHP版本是5.6,要安装高版本的PHP,其实也可以用yum install命令直接安装
  1. 安装之前先卸载虚拟机上其他版本的PHP
    yum -y remove php*
  2. 由于linux的yum源不存在PHP7.x,所有我们要改yum源(两条命令)
    rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
    rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
  3. 安装PHP及其扩展,比如安装php7.2
    yum -y install php72w php72w-cli php72w-common php72w-devel php72w-embedded php72w-fpm php72w-gd php72w-mbstring php72w-mysqlnd php72w-opcache php72w-pdo php72w-xml
  4. 安装完成后,php -v查看安装的PHP版本,版本号正确,说明PHP安装成功

修改php.ini 解决mbstring扩展异常

  1. yum install php-mbstring # 如果是remi,则yum --enablerepo=remi install php-mbstring
  2. vim /etc/php.ini # 打开mbstring相关的选项。
[mbstring]
 language for internal character representation.
 http://php.net/mbstring.language
 mbstring.language = Chinese
 internal/script encoding.
 Some encoding cannot work as internal encoding.
 (e.g. SJIS, BIG5, ISO-2022-*)
 http://php.net/mbstring.internal-encoding
mbstring.internal_encoding = UTF-8
 http input encoding.
 http://php.net/mbstring.http-input
 mbstring.http_input = auto
 http output encoding. mb_output_handler must be
 registered as output buffer to function
 http://php.net/mbstring.http-output
 mbstring.http_output = UTF-8
 enable automatic encoding translation according to
 mbstring.internal_encoding setting. Input chars are
 converted to internal encoding by setting this to On.
 Note: Do _not_ use automatic encoding translation for
       portable libs/applications.
 http://php.net/mbstring.encoding-translation
 mbstring.encoding_translation = On

CentOS下版本查询及手工修改路径案例

  • 可用命令参考
  1. php -v
  2. httpd -v
  3. rpm -qa |grep php
  4. rpm -qa |grep httpd
  5. php -m # 查看下加载情况
  • 案例:查找系统里PHP相关的目录或文件并手工修改profile
  1. find / -name php # 查看列出的 PHP 版本的信息
  2. /usr/bin/php -v # // PHP 5.4.45
  3. /usr/local/php/bin/php -v # // PHP 7.2.18
  4. 删除 /usr/bin/ 目录下的所有PHP相关的目录或文件
    rm -rf ./php
    rm -rf ./php-cgi
    rm -rf ./php-config
    rm -rf ./phpize
  5. 环境变量中添加自己编译的 PHP 的路径
    vim /etc/profile
    Shift + G 定位到最后一行,添加自己编译的 PHP 的路径
    export PATH="/usr/local/php/bin:$PATH"
  6. 保存退出,执行
    source /etc/profile
  7. 再次检查 PHP 版本
    php -v
  8. 通过yum安装PHP7
    rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
    yum -y install php70w-devel
  9. 报错冲突了
    --> Finished Dependency Resolution
    Error: php70w-common conflicts with php-common-5.4.16-43.el7_4.x86_64
    You could try using --skip-broken to work around the problem
    You could try running: rpm -Va --nofiles --nodigest
  10. 移除php-common
    yum remove php-common
  11. 再次执行
    yum -y install php70w-devel
  12. 成功!!!

Linux下修改文件属性及文件简单操作命令

  • cd pwd
  1. NO1. 显示当前路径 [root@rehat root]# pwd
  2. NO2. 返回用户主目录 [root@rehat root]# cd
  3. NO3. 改变到其它路径 [root@rehat root]# cd /etc
  4. NO4. 返回到上一级目录 [root@rehat root]# cd ..
  5. NO5. 返回到根目录 [root@rehat root]# cd /
  • 查询文件或文件夹的CentOS常用命令 find
  1. NO1. 查找当前用户主目录下的所有文件 [root@rehat root]# find ~
  2. NO2. 让当前目录中文件属主具有读、写权限,并且文件所属组的用户和其他用户具有读权限的文件; [root@rehat root]# find . -perm 644 -exec ls -l {} \;
  3. NO3. 为了查找系统中所有文件长度为0的普通文件,并列出它们的完整路径;[root@rehat root]# find / size 0 -type f -exec ls -l {} \;
  4. NO4. 查找/var/logs目录中更改时间在7日以前的普通文件,并在删除之前询问它们;[root@rehat root]# find /var/logs -mtime +7 -type f -ok rm -i {} \;
  5. NO5. 为/找系统中所有属于root组的文件;[root@rehat root]# find / -group root -exec ls -l {} \;
  6. NO6. find命令将删除当目录中访问时间在7日以来、含有数字后缀的admin.log文件[root@rehat root]# find . -name "admin.log[0-9][0-9][0-9]" -atime -7 -ok rm { } \;
  7. NO7. 为了查找当前文件系统中的所有目录并排序[root@rehat root]# find . -type d | sort
  8. NO8. 为了查找系统中所有的rmt磁带设备[root@rehat root]# find /dev/rmt
  • 显示文件/文件夹清单的CentOS常用命令 ls / dir
  1. NO1. 显示所有文件,包括以.开头的隐含文件[root@rehat root]# ls -a
  2. NO2. 显示文件的详细信息[root@rehat root]# ls -l
  3. NO3. 显示当前目录及所有子目录信息[root@rehat root]# ls -Rl
  4. NO4. 以时间排序显示目录,这在找最新文件有用[root@rehat root]# ls -tl
  5. NO5. 以文件大小排序[root@rehat root]# ls -Sl
  6. NO6. 显示文件大小,并按大小排序[root@rehat root]# ls -s -l -S
  • 移动或更改文件/文件夹名称的CentOS常用命令 mv 与 cp命令用法相似
  1. NO1. 若移动目标文件已存在,要在移动之前,先备份原来的目录文件[root@rehat root]# mv -b test.txt test2/

这样在 test2 下将有两个文件 test.txt 及 text.txt~,其中 test.txt~ 是备份文件,test.txt是新的文件

  1. NO2. 若移动目标文件已存在,但不想弹出是否覆盖的提示,直接覆盖[root@rehat root]# mv -f test.txt test2/
  2. NO3. 当源与目标都拥有同一个文件,若源文件比目标新则移动,否则不移动[root@rehat root]# mv -u test.txt test2/
  3. NO4. 更改文件名称[root@rehat root]# mv test.txt test2.txt
  4. NO5. 更改目录名称[root@rehat root]# mv /test2 /test2_2[/size]
  • 创建/改变文件系统的CentOS常用命令
  1. NO1. 创建文件系统类型
    1. [root@rehat root]# umount /dev/sdb1
    2. [root@rehat root]# mkfs -t ext3 /dev/db1
    3. [root@rehat root]# mount /dev/sdb1 /practice
  • 改变文件或文件夹权限的CentOS常用命令chmod
  1. NO1. 将自己的笔记设为只有自己才能看

[root@rehat root]# chmod go-rwx test.txt 或者 [root@rehat root]# chmod 700 test.txt

  1. NO2. 同时修改多个文件的权限

[root@rehat root]# chmod 700 test1.txt test2.txt

  1. NO3. 修改一个目录的权限,包括其子目录及文件

[root@rehat root]# chmod 700 -R test

  • 改变文件或文件夹拥有者的CentOS常用命令

chown 该命令只有 root 才能使用

  1. NO1. 更改某个文件的拥有者

[root@rehat root]# chown jim:usergroup test.txt

  1. NO2. 更改某个目录的拥有者,并包含子目录

[root@rehat root]# chown jim:usergroup -R test

  • 查看文本文件内容的CentOS常用命令cat
  1. NO1. 查看文件内容,并在每行前面加上行号

[root@rehat root]# cat -n test.txt

  1. NO2. 查看文件内容,在不是空行的前面加上行号

[root@rehat root]# cat -b test.txt

  1. NO3. 合并两个文件的内容

[root@rehat root]# cat test1.txt test2.txt > test_new.txt

  1. NO4. 全并两具文件的内容,并追回到一个文件

[root@rehat root]# cat test1.txt test2.txt >> test_total.txt

  1. NO5. 清空某个文件的内容

[root@rehat root]# cat /dev/null > test.txt NO6. 创建一个新的文件

[root@rehat root]# cat > new.txt 按 CTRL + C 结束录入 编辑文件文件的CentOS常用命令vi

NO1. 新建档案文件

[root@rehat root]# vi newfile.txt NO2. 修改档案文件

[root@rehat root]# vi test.txt test.txt 已存在 NO3. vi 的两种工作模式:命令模式,编辑模式

NO4. 进入 vi 后为命令模式,按 Insrt 键进入编辑模式

按 ESC 进入命令模式,在命令模式不能编辑,只能输入命令

NO5. 命令模式常用命令

w 保存当前文档
q 直接退出 vi
wq 先保存后退出 。

创建目录的CentOS常用命令mkdir

NO1. 在当前路径创建一级目录

[root@rehat root]# mkdir test NO2. 在当前路径创建多级目录

[root@rehat root]# mkdir -p mytest/test1/test1_1 NO3. 在创建目录的同时给新建的目录赋权限

[root@rehat root]# mkdir -m 777 testmod 这样任何人对此目录都有任何权限

复制文件与文件夹的CentOS常用命令cp

NO1. 复制指定目录的文件到当前目录,并重命名

[root@rehat root]# cp ~/.bashrc bashrc_bak NO2. 强制复制指定目录的文件到当前目录,而不管当前目录是否含有该文件

[root@rehat root]# cp -f ~/.bashrc bashrc NO2. 复制指定目录到当前目录

[root@rehat root]# cp -r /root/test . [root@rehat root]# cp -r /root/test/ . 两者效果一样,在复制目录时,会将源路径的最后一级目录全部复制过去,包括它本身。

NO3. 复制指定目录的文件到指定目录

[root@rehat root]# cp ~/.bashrc /bak/.bashrc NO4. 在复制时将源文件的全部属性也复制过来。若不指定参数,则目标文件与源文件属性可能不一致。

[root@rehat root]# cp -a ~/.bashrc /bak/.bashrc NO5. 若两个文件夹要保证同步,一个文件的改了,另一个文件也跟着改,但是要保证两个文件的文件都是最新的。

[root@rehat root]# cp -u /src/.bashrc /bak_src/bashrc 建立链接文件,包括硬链接与软链接的CentOS常用命令ln

NO1. 建立类似于 Windows 的快捷方式

[root@rehat root]# ln -s test.txt test.txt_slnk NO2. 当想备份一个文件,但空间又不够,则可以为该文件建立一个硬连接。这样,就算原文件删除了,只要该 链接文件没被删除,则在存储空间里还是没有被删除。

[root@rehat root]# ln -l test.txt test.txt_hlnk 使用CentOS常用命令查看cpu

more /proc/cpuinfo | grep "model name" grep "model name" /proc/cpuinfo [root@localhost /]# grep "CPU" /proc/cpuinfo model name  : Intel(R) Pentium(R) Dual CPU E2180 @ 2.00GHz model name  : Intel(R) Pentium(R) Dual CPU E2180 @ 2.00GHz 如果觉得需要看的更加舒服

grep "model name" /proc/cpuinfo | cut -f2 -d: 使用CentOS常用命令查看内存

grep MemTotal /proc/meminfo grep MemTotal /proc/meminfo | cut -f2 -d: free -m |grep "Mem" | awk '{print $2}' 使用CentOS常用命令查看cpu是32位还是64位 查看CPU位数(32 or 64)

getconf LONG_BIT 使用CentOS常用命令查看当前linux的版本

more /etc/redhat-release cat /etc/redhat-release 使用CentOS常用命令查看内核版本

uname -r uname -a 使用CentOS常用命令查看当前时间

date上面已经介绍如何同步时间了

使用CentOS常用命令查看硬盘和分区

df -h fdisk -l 也可以查看分区

du -sh 可以看到全部占用的空间

du /etc -sh 可以看到这个目录的大小

使用CentOS常用命令查看安装的软件包,查看系统安装的时候装的软件包

cat -n /root/install.log more /root/install.log | wc -l 查看现在已经安装了那些软件包

rpm -qa rpm -qa | wc -l yum list installed | wc -l 不过很奇怪,我通过rpm,和yum这两种方式查询的安装软件包,数量并不一样。没有找到原因。

使用CentOS常用命令查看键盘布局

cat /etc/sysconfig/keyboard cat /etc/sysconfig/keyboard | grep KEYTABLE | cut -f2 -d= 使用CentOS常用命令查看selinux情况

sestatus sestatus | cut -f2 -d: cat /etc/sysconfig/selinux 使用CentOS常用命令查看ip,mac地址

在ifcfg-eth0 文件里你可以看到mac,网关等信息。

 ifconfig  cat /etc/sysconfig/network-scripts/ifcfg-eth0 | grep IPADDR  cat /etc/sysconfig/network-scripts/ifcfg-eth0 | grep IPADDR | cut -f2 -d=  ifconfig eth0 |grep "inet addr:" |awk '{print $2}'|cut -c 6-  ifconfig   | grep 'inet addr:'| grep -v '127.0.0.1' | cut -d: -f2 | awk '{ print $1}'  

查看网关

cat /etc/sysconfig/network

查看dns

cat /etc/resolv.conf 使用CentOS常用命令查看默认语言

echo $LANG $LANGUAGE cat /etc/sysconfig/i18n 使用CentOS常用命令查看所属时区和是否使用UTC时间

cat /etc/sysconfig/clock 使用CentOS常用命令查看主机名

hostname cat /etc/sysconfig/network 修改主机名就是修改这个文件,同时最好也把host文件也修改。

使用CentOS常用命令查看开机运行时间

uptime 09:44:45 up 67 days, 23:32, ... 看来刚才确实是网段的问题,我的机器还是67天前开机的。

系统资源使用情况 vmstat 1 -S m procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu------ r b swpd free buff cache si so bi bo in cs us sy id wa st 0 0 0 233 199 778 0 0 4 25 1 1 3 0 96 0 0 0 0 0 233 199 778 0 0 0 0 1029 856 13 1 86 0 0 删除文件的CentOS常用命令rm

NO1. 删除当前目录的文件

[root@rehat root]# rm test.txt NO2. 强制删除当前目录的文件,不弹出提示

[root@rehat root]# rm -f test.txt NO3. 强制删除整个目录,包括目录与文件全部删除,需要管理员权限

[root@rehat root]# rm -r -f test 删除文件夹的CentOS常用命令rmdir

NO1. 删除一个空目录

[root@rehat root]# rmdir emptydir NO2. 删除多级空目录

[root@rehat root]# rmdir -p emptydir/d1/d11 挂载文件系统与卸载文件系统的CentOS常用命令

mount / umount

NO1. 挂载光驱

[root@rehat root]# mount -t iso9660 /dev/cdrom /mnt/cdrom NO2. 挂载光驱,支持中文

[root@rehat root]# mount -t iso9660 -o codepage=936,iocharset=cp936 /dev/cdrom /mnt/cdrom NO3. 挂载 Windows 分区,FAT文件系统

[root@rehat root]# mount -t vfat /dev/hda3 /mnt/cdrom NO4. 挂载 Windows 分区,NTFS文件系统

[root@rehat root]# mount -t ntfs -o iocharset=cp936 /dev/hda7 /mnt/had7 No5. 挂载 ISO 文件

[root@rehat root]# mount -o loop /abc.iso /mnt/cdrom NO6. 挂载 软驱

[root@rehat root]# mount /dev/fd0 /mnt/floppy NO7. 挂载闪盘

[root@rehat root]# mount /dev/sda1 /mnt/cdrom NO8. 挂载 Windows 操作系统共享的文件夹

[root@rehat root]# mount -t smbfs -o username=guest,password=guest //machine/path /mnt/cdrom NO9. 显示挂载的文件系统

[root@rehat root]# mount [root@rehat root]# cat /etc/fstab 显示系统启动自动加载的文件系统 [root@rehat root]# cat /etc/mtab 显示当前加载的文件系统

find: ‘/run/user/1000/gvfs’: 权限不够 的解决办法

官方说这是一个bug[bug#615848],原因是FUSE文件系统和权限不配的问题,全局搜索时碰到它就会退出报错。 其实这个目录是空的,查不查都没关系。所以,以下解决方式比较简粗暴:

umount /run/user/1000/gvfs    // 卸载该文件
rm -rf /run/user/1000/gvfs    // 删除该文件

php版本升级或者更改后发生httpd服务异常的问题处理

apache不知道php版本已更改,因此php网页用不了apache也就是httpd。

  • 比如在/var/www/html/目录下建立一个info.php文件,该目录是网页的根目录,也就是在浏览器中访问:IP/info.php即可出现info.php的内容。
  1. info.php文件如下:
    sudo vim /etc/www/html/info.php
    <?php phpinfo();?>
  2. 在浏览器输入IP/info.php,发现找不到该页面。因为说过apache不知道我们改了php版本,导致解析失败。
  • 因此为了让apache支持php7.2,需要修改apache的配置文件:
  1. 首先,找到php的配置文件:php.ini,利用find命令:
    sudo find / -name php.ini # 通常情况下位于/etc中,也就是/etc/php.ini。
  2. 然后找到apache的配置文件:httpd.conf
    sudo find / -name httpd.conf # 位置如下:/etc/httpd/conf/httpd.conf
  3. 然后修改该文件,在该文件最后一行加上:
    PHPIniDir /etc/php.ini # 表示告诉apache,php的配置信息文件。
  4. 保存即可,然后重新在浏览器中输入IP/info.php,页面内容正常即表示成功!
  5. 可以使用如下命令查询httpd状态:
    systemctl status httpd.service -l

修改Apache默认端口80

  1. vim /etc/httpd/conf/httpd.conf
  2. 修改这个地方
    #Listen 12.34.56.78:80
    #把80改为你设置的端口,如:5555
    Listen 5555
  3.  :wq # 保存修改
  4. Apache service httpd restart

CentOS防火墙设置

  1. 防火墙一般命令
    yum install firewalld #查看已经安装的firewall文件
    service firewalld start
    service firewalld stop/disable
    ps -ef |grep firewall #查看当前firewall运行的进程
    service firewalld restart  #重启防火墙
    service firewalld status    #查看防火墙的状况
    firewall-cmd --version     #查看版本
    firewall-cmd --get-zones  #查看防火墙区域
    firewall-cmd --get-default-zone  #查看防火墙的默认空间
    firewall-cmd --list-all-zones     #查看所有空间的配置信息
    firewall-cmd --list-all # 查看防火墙规则
  2. 查询、开放、关闭端口
    firewall-cmd --query-port=8080/tcp # 查询端口是否开放
    firewall-cmd --permanent --add-port=80/tcp # 开放80端口
    firewall-cmd --permanent --remove-port=8080/tcp # 移除端口
    firewall-cmd --reload #重启防火墙(修改配置后要重启防火墙)
  3. 参数解释
    1. firwall-cmd:是Linux提供的操作firewall的一个工具;
    2. --permanent:表示设置为持久;
    3. --add-port:标识添加的端口;
  • 开放80tcp端口案例:
  1. 首先检查80端口是否开放
    firewall-cmd --query-port=80/tcp
  2. 如果开启返回yes,没开启返回的是no。
  3. 开放80端口。permanent代表永久开放
    firewall-cmd --permanent --zone=public --add-port=80/tcp
  4. reload参数
    firewall-cmd --reload

phpMyAdmin安装后无法访问

  • phpMyAdmin 的默认安装目录是 /usr/share/phpMyAdmin,同时会在 Apache 的配置文件目录中自动创建虚拟主机配置文件 /etc/httpd/conf.d/phpMyAdmin.conf(区分大小写)。
  • 默认情况下,CentOS 7上的phpMyAdmin只允许从回环地址(127.0.0.1)访问。
  • 为了能远程连接,你需要改动它的配置。 vi /etc/httpd/conf.d/phpMyAdmin.conf
    sudo vi /etc/httpd/conf.d/phpMyAdmin.conf
    • 修改后的文件内容
      <Directory /usr/share/phpMyAdmin/>
      AddDefaultCharset UTF-8
      <IfModule mod_authz_core.c>
      # Apache 2.4
      <RequireAny>
      # Require ip 127.0.0.1 #注释掉
      # Require ip ::1 #注释掉
      Require all granted #新添加
      </RequireAny>
      </IfModule>
      <IfModule !mod_authz_core.c>
      # Apache 2.2
      Order Deny,Allow
      Deny from All
      Allow from 127.0.0.1
      Allow from ::1
      </IfModule>
      </Directory>
      <Directory /usr/share/phpMyAdmin/setup/>
      <IfModule mod_authz_core.c>
      # Apache 2.4
      <RequireAny>
      #Require ip 127.0.0.1 #注释掉
      #Require ip ::1 #注释掉
      Require all granted #新添加
      </RequireAny>
      </IfModule>
      <IfModule !mod_authz_core.c>
      # Apache 2.2
      Order Deny,Allow
      Deny from All
      Allow from 127.0.0.1
      Allow from ::1
      </IfModule>
      </Directory>
  • 最后,重启httpd使改动生效。
    systemctl restart httpd
  • 而一般情况下不需要,也不建议对phpMyAdmin.conf的修改。
  • 初次安装完phpmyadmin,仅仅需要重启apache
    systemctl restart httpd

U盘挂载mount命令

  • 挂载
    $ mount /dev/hda2 /home
    第一个叁数是与包括文件系统的磁盘或分区相关的设备文件。
    第二个叁数是要mount到的目录。
  • 卸载挂载点
    $ umount /dev/hda2
    $ umount /usr

参数可以是设备文件或安装点。

  • mount详细介绍
  1. 如果想在运行的Linux下访问其它文件系统中的资源的话,就要用mount命令来实现。
    1. mount [-参数] [设备名称] [挂载点]
    2. 其中常用的参数有:
      -a 安装在/etc/fstab文件中类出的所有文件系统。
      -f 伪装mount,作出检查设备和目录的样子,但并不真正挂载文件系统。
      -n 不把安装记录在/etc/mtab文件中。
      -r 讲文件系统安装为只读。
      -v 详细显示安装信息。
      -w 将文件系统安装为可写,为命令默认情况。
      -t 指定设备的文件系统类型,常见的有:
      1. ext2 linux目前常用的文件系统
        msdos MS-DOS的fat,就是fat16
        vfat windows98常用的fat32
        nfs 网络文件系统
        iso9660 CD-ROM光盘标准文件系统
        ntfs windows NT/2000/XP的文件系统
        auto 自动检测文件系统
    1. -o 指定挂载文件系统时的选项,有些也可写到在/etc/fstab中。常用的有:
      defaults 使用所有选项的默认值(auto、nouser、rw、suid)
      auto/noauto 允许/不允许以 –a选项进行安装
      dev/nodev 对/不对文件系统上的特殊设备进行解释
      exec/noexec 允许/不允许执行二进制代码
      suid/nosuid 确认/不确认suid和sgid位
      user /nouser 允许/不允许一般用户挂载
      codepage=XXX 代码页
      iocharset=XXX 字符集
      ro 以只读方式挂载
      rw 以读写方式挂载
      remount 重新安装已经安装了的文件系统
      loop 挂载回旋设备
    2. 需要注意的是,挂载点必须是一个已经存在的目录,这个目录可以不为空,但挂载后这个目录下以前的内容将不可用,umount以后会恢复正常。使用多个-o参数的时候,-o只用一次,参数之间用半角逗号隔开:
      CODE:
      # mount –o remount,rw /
    3. 例如要挂载windows下文件系统为FAT32的D盘,一般而言在Linux下这个分区对应/dev/hda5,根据具体的分区情况会有不同,这里就以hda5来举例说明:
      CODE:
      # mkdir /mnt/hda5 //创建hda5的目录作为挂载点,位置和目录名可自定义//
      # mount -t vfat /dev/hda5 /mnt/hda5
    4. 一般而言,Linux会自动探测分区的文件系统,除非让你指定时,否则-t vfat 可以省掉。
      CODE:
      # mount /dev/hda5 /mnt/hda5
      这样就可以进入/mnt/hda5目录去访问分区中的资源了。

ntfs格式识别

  • 安装ntfs支持
    yum makecache
    yum install ntfs-3g
  • 查看盘符
    fdisk -l
  • 挂载
    mount -t ntfs-3g /dev/sdb1 /mnt/usb

文件查看及复制操作

  1. 查看当前文件夹下面各个文件的大小
    ll -lh
  2. 查看某文件夹占用总的空间大小
    du -h --max-depth=1 /usr/local/
    1. 参数--max-depth用来指定深入目录的层数,为1就指定1层
    2. 使用"*",可以得到文件的使用空间大小
      du -h --max-depth=1 /usr/Java/jdk1.6.0_25/*
  3. 查看磁盘空间的使用空间
    df -h
  4. 值得注意的是,du和df命令异同
    1. du 统计文件大小相加
    2. df 统计数据块使用情况
    3. 如果有一个进程在打开一个大文件的时候,这个大文件直接被rm 或者mv掉,则du会更新统计数值,df不会更新统计数值,还是认为空间没有释放。直到这个打开大文件的进程被Kill掉。
  5. 如此一来在定期删除 /var/spool/clientmqueue下面的文件时,如果没有杀掉其进程,那么空间一直没有释放。
  6. 使用下面的命令杀掉进程之后,系统恢复。
    fuser -u /var/spool/clientmqueue

挂载nas/共享盘

  1. mkdir /mnt/nas # 先创建一个挂载目录
  2. mount -o username=xxxxx,password=xxxxxxxx,iocharset=utf8 //192.168.x.xx/xxx /mnt/nas # 如果smb版本发生冲突情况下,增加版本参数,如:vers=2.0
  3. 参数说明:
    1. username=xxxxx [nas用户名]
    2. password=xxxxxxxx [nas密码]
    3. iocharset=utf8 [路径中如有中文则添加此项,支持中文路径]
    4. //192.168.x.xx/xxx [nas路径]
    5. /mnt/nas [挂载路径]
      1. 参数之间用,(逗号)分隔。
      2. 如果密码中有,号,则以上命令无法执行完成,因为需要参数之间用“,”逗号分隔,导致会认为提前结束了。所以可以用下面方法,创建一个环境变量:
        1. export PASSWD='!3\5g6,B'
        2. mount -o username=xxxxx,iocharset=utf8 //192.168.xx.xx/xxx /mnt/nas
      3. 注:shell会自动查找PASSWD
  4. umount -l /mnt/nas # 使用完成后将其卸载
  5. vi /etc/rc.d/rc.local # 如果需要开机自动挂载,写入开机文件里面
  • Linux mount NAS 服务器,经常报“mount error(95): Operation not supported “,查阅资料是因为新版kernel问题,具体原因就不知道了,解决方法举例如下:
  1. 增加选项: vers=1.0
    mount -t cifs //192.168.8.127/test /dataNAS -o username=test,password=test,domain=DOMAIN,vers=1.0
    mount.cifs //192.168.8.127/test /data4t/sharedir -o iocharset=utf8,username=”test”,password=”test”,sec=ntlm,vers=1.0