1.linux中set的用法
linux set 命令功能说明:设置shell。
语 法:set [+-abCdefhHklmnpPtuvx]补充说明:用set 命令可以设置各种shell选项或者列 出shell变量.单个选项设置常用的特性.在某些选项之后-o参数将特殊特性打开.在某些选项之后使用+o参数将关闭某些特性,不带任何参数的set命 令将显示shell的全部变量.除非遇到非法的选项,否则set总是返回ture.参 数:allexport -a 从设置开始标记所有新的和修改过的用于输出的变量 braceexpand -B 允许符号扩展,默认选项 emacs 在进行命令编辑的时候,使用内建的emacs编辑器, 默认选项errexit -e 如果一个命令返回一个非0退出状态值(失败),就退出.histexpand -H 在做临时替换的时候允许使用!和!! 默认选项history 允许命令行历史,默认选项ignoreeof 禁止coontrol-D的方式退出shell,必须输入exit。interactive-comments 在交互式模式下, #用来表示注解keyword -k 为命令把关键字参数放在环境中monitor -m 允许作业控制noclobber -C 保护文件在使用重新动向的时候不被覆盖noexec -n 在脚本状态下读取命令但是不执行,主要为了检查语法结构。
noglob -d 禁止路径名扩展,即关闭通配符 notify -b 在后台作业以后通知客户nounset -u 在扩展一个没有的设置的变量的时候, 显示错误的信息 onecmd -t 在读取并执行一个新的命令后退出 physical -P 如果被设置,则在使用pwd和cd命令时不使用符号连接的路径 而是物理路径posix 改变shell行为以便符合POSIX要求privileged 一旦被设置,shell不再读取.profile文件和env文件 shell函数也不继承任何环境verbose -v 为调试打开verbose模式vi 在命令行编辑的时候使用内置的vi编辑器xtrace -x 打开调试回响模式设置系统环境变量在本站下面这两篇文章中有详细说明:设置环境变量永久生效 export PS1 :扩展阅读:set,env和export这三个命令都可以用来显示shell变量,其区别?set 用来显示本地变量env 用来显示环境变量export 用来显示和设置环境变量set 显示当前shell的变量,包括当前用户的变量env 显示当前用户的变量export 显示当前导出成用户变量的shell变量每个shell有自己特有的变量(set)显示的变量,这个和用户变量是不同的,当前用户变量和你用什么shell无关,不管你用什么shell都在,比如HOME,SHELL等这些变量,但shell自己的变量不同shell是不同的,比如BASH_ARGC, BASH等,这些变量只有set才会显示,是bash特有的,export不加参数的时候,显示哪些变量被导出成了用户变量,因为一个shell自己的变量可以通过export “导出”变成一个用户变量[root@linux ~]# aaa=bbb[root@linux ~]# echo $aaabbb[root@linux ~]# set|grep aaaaaa=bbb[root@linux ~]# env|grep aaa[root@linux ~]# export aaa[root@linux ~]# env|grep aaaaaa=bbb扩展资料二:set、env、export——Linux中的环境变量命令Linux是一个多用户的操作系统。每个用户登录系统后,都会有一个专用的运行环境。
通常每个用户默认的环境都是相同的,这个默认环境实际上就是一组环境 变量的定义。用户可以对自己的运行环境进行定制,其方法就是修改相应的系统环境变量。
什么是环境变量环境变量是一个具有 特定名字的对象,它包含了一个或者多个应用程序所将使用到的信息。许多用户(特别是那些刚接触Linux的新手)发现这些变量有些怪异或者难以控制。
其 实,这是个误会:通过使用环境变量,你可以很容易的修改一个牵涉到一个或多个应用程序的配置信息。常见的环境变量对于 PATH和HOME等环境变量大家都不陌生。
PATH能够指定命令的搜索路径,那么动态链接库的路径用什么变量指定呢?或者就是在 PATH里面?比如有一个程序需要/usr/local/lib下面的一个库文件,应该怎么指定其路径呢?经常看到有些变量如 LD_LIBRARY_PATH,LIBPATH,CLASSPATH等,他们之间有什么不同和关系?除此之外,还有下面一些常见环境变 量。◆ HISTSIZE是指保存历史命令记录的条数。
◆ LOGNAME是指当前用户的登录名。◆ HOSTNAME是指主机的名称,许多应用程序如果要用到主机名的话,通常是从这个环境变量中来取得的。
◆ SHELL是指当前用户用的是哪种Shell。◆ LANG/LANGUGE是和语言相关的环境变量,使用多种语言的用户可以修改此环境变量。
◆ MAIL是指当前用户的邮件存放目录。◆ PS1是基本提示符,对于root用户是#,对于普通用户是$。
PS2是附属提示符,默认是“>”。可以通过修改此环境变量来修改当前的命令符,比 如下列命令会将提示符修改成字符串“Hello,My NewPrompt ”。
2.linux命令里,grep * 是什么意思
任意一个字节 . 与重复字节 *
这两个符号在正则表达式的意义如下:
. (小数点):代表『一定有一个任意字节』的意思;
* (星号):代表『重复前一个字符, 0 到无穷多次』的意思,为组合形态
假设我需要找出 g??d 的字串,亦即共有四个字节, 起头是 g 而结束是 d ,我可以这样做:
[root@ments 在交互式模式下, #用来表示注解keyword -k 为命令把关键字参数放在环境中monitor -m 允许作业控制noclobber -C 保护文件在使用重新动向的时候不被覆盖noexec -n 在脚本状态下读取命令但是不执行,主要为了检查语法结构。
noglob -d 禁止路径名扩展,即关闭通配符 notify -b 在后台作业以后通知客户nounset -u 在扩展一个没有的设置的变量的时候, 显示错误的信息 onecmd -t 在读取并执行一个新的命令后退出 physical -P 如果被设置,则在使用pwd和cd命令时不使用符号连接的路径 而是物理路径posix 改变shell行为以便符合POSIX要求privileged 一旦被设置,shell不再读取.profile文件和env文件 shell函数也不继承任何环境verbose -v 为调试打开verbose模式vi 在命令行编辑的时候使用内置的vi编辑器xtrace -x 打开调试回响模式设置系统环境变量在本站下面这两篇文章中有详细说明:设置环境变量永久生效 export PS1 :扩展阅读:set,env和export这三个命令都可以用来显示shell变量,其区别?set 用来显示本地变量env 用来显示环境变量export 用来显示和设置环境变量set 显示当前shell的变量,包括当前用户的变量env 显示当前用户的变量export 显示当前导出成用户变量的shell变量每个shell有自己特有的变量(set)显示的变量,这个和用户变量是不同的,当前用户变量和你用什么shell无关,不管你用什么shell都在,比如HOME,SHELL等这些变量,但shell自己的变量不同shell是不同的,比如BASH_ARGC, BASH等,这些变量只有set才会显示,是bash特有的,export不加参数的时候,显示哪些变量被导出成了用户变量,因为一个shell自己的变量可以通过export “导出”变成一个用户变量[root@linux ~]# aaa=bbb[root@linux ~]# echo $aaabbb[root@linux ~]# set|grep aaaaaa=bbb[root@linux ~]# env|grep aaa[root@linux ~]# export aaa[root@linux ~]# env|grep aaaaaa=bbb扩展资料二:set、env、export——Linux中的环境变量命令Linux是一个多用户的操作系统。每个用户登录系统后,都会有一个专用的运行环境。
通常每个用户默认的环境都是相同的,这个默认环境实际上就是一组环境 变量的定义。用户可以对自己的运行环境进行定制,其方法就是修改相应的系统环境变量。
什么是环境变量环境变量是一个具有 特定名字的对象,它包含了一个或者多个应用程序所将使用到的信息。许多用户(特别是那些刚接触Linux的新手)发现这些变量有些怪异或者难以控制。
其 实,这是个误会:通过使用环境变量,你可以很容易的修改一个牵涉到一个或多个应用程序的配置信息。常见的环境变量对于 PATH和HOME等环境变量大家都不陌生。
PATH能够指定命令的搜索路径,那么动态链接库的路径用什么变量指定呢?或者就是在 PATH里面?比如有一个程序需要/usr/local/lib下面的一个库文件,应该怎么指定其路径呢?经常看到有些变量如 LD_LIBRARY_PATH,LIBPATH,CLASSPATH等,他们之间有什么不同和关系?除此之外,还有下面一些常见环境变 量。◆ HISTSIZE是指保存历史命令记录的条数。
◆ LOGNAME是指当前用户的登录名。◆ HOSTNAME是指主机的名称,许多应用程序如果要用到主机名的话,通常是从这个环境变量中来取得的。
◆ SHELL是指当前用户用的是哪种Shell。◆ LANG/LANGUGE是和语言相关的环境变量,使用多种语言的用户可以修改此环境变量。
◆ MAIL是指当前用户的邮件存放目录。◆ PS1是基本提示符,对于root用户是#,对于普通用户是$。
PS2是附属提示符,默认是“>”。可以通过修改此环境变量来修改当前的命令符,比 如下列命令会将提示符修改成字符串“Hello,My NewPrompt ”。
4.linux下的yum怎么读
yum读音为:英 [j?m] 美 [j?m]
Yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器。基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系。
例句:
1、Create the yum repository metadata with the createrepo command.
使用createrepo命令创建yum存储库元数据。
2、Before you install Nagios, use yum to install Apache, the CC compiler, and the GD development libraries.
在安装Nagios之前,使用yum来安装Apache、CC编译器和GD开发库。
扩展资料:
Yum的软件包来源:
可供Yum下载的软件包包括Fedora本身的软件包以及源自rpmfusion和rpm.的Fedora Extras,全部是由Linux社区维护的,并且基本是自由软件。所有的包都有一个独立的PGP签名,主要是为了用户的系统安全。
参考资料:百度百科-yum
5.linux硬盘安装具体步骤,谢谢
我装的是fefora 9版本的
1.下载Fedora-9-i386-DVD,放在FAT32分区(不能放在NTFS分区)。
2.提取出isolinux文件夹下面的两个文件 initrd.img 和 vmlinuz 放在C盘根目录下。
3.下载grub4dos,解压提取出个三个文件 grldr grub.exe 和 menu.lst 放在C盘根目录下。
4.用记事本打开menu.lst,最后添加上:
title Install Fedora 9
kernel (hd0,0)/vmlinuz
initrd (hd0,0)/initrd.img
5.用记事本打开C盘根目录下的系统隐藏文件boot.ini,后面加上如下内容:
c:\grldr="GRUB"
6.重启,选择"GRUB” ,再选择"Install Fedora 9”,即可进入安装界面。
6.什么是linux核心数据结构
操作系统可能包含许多关于系统当前状态的信息。
当系统发生变化时,这些数据结构必须做相应的改变以反映这些情况。例如,当用户登录进系统时将产生一个新的进程。
核心必须创建表示新进程的数据结构,同时 将它和系统中其他进程的数据结构连接在一起。 大多数数据结构存在于物理内存中并只能由核心或者其子系统来访问。
数据结构包括数据和指针;还有其他数据结构的地址或者子程序的地址。它们混在一起让Linux核心数据结构看上去非常混乱。
尽管可能被几个核心子系统同时用到,每个数据结构都有其专门的用途。理解Linux核心的关键是理解它的数据结构以及Linux核心中操纵这些数据结构的各种函数。
本书把Linux核心的 描叙重点放在数据结构上,主要讨论每个核心子系统的算法,完成任务的途径以及对核心数据结构的使用。 2.3.1 连接列表Linux使用的许多软件工程的技术来连接它的数据结构。
在许多场合下,它使用linked或者chained数据结构。 每个数据结构描叙某一事物,比如某个进程或网络设备,核心必须能够访问到所有这些结构。
在链表结构中,个根节点指针包含第一个结构的地址,而在每个结构中又包含表中下一个结构的指针。表的最后一项必须是0或者NULL,以表明这是表的尾部。
在双向链表中,每个结构包含着指向表中前一结构和后一结构的指针。使用双向链表的好处在于更容易在表的中部添加与删除节点,但需要更多的内存操作。
这是一种典型的操作系统开销与CPU循环之间的折中。 2.3.2 散列表链表用来连接数据结构比较方便,但链表的操作效率不高。
如果要搜寻某个特定内容,我们可能不得不遍历整个链表。Linux使用另外一种技术:散列表来提高效率。
散列表是指针的数组或向量,指向内存中连续的相邻数据集合。散列表中每个指针元素指向一个独立链表。
如果你使用数据结构来描叙村子里的人,则你可以使用年龄作为索引。为了找到某个人的数据,可以在人口散列表中使用年龄作为索引,找到包含此人特定数据的数据结构。
但是在村子里有很多人的年龄相同,这样散列表指针变成了一个指向具有相同年龄的人数据链表的指针。搜索这个小链表的速度显然要比搜索整个数据链表快得多。
由于散列表加快了对数据结构的访问速度,Linux经常使用它来实现Caches。Caches是保存经常访问的信息的子集。
经常被核心使用的数据结构将被放入Cache中保存。Caches的缺点是比使用和维护单一链表和散列表更复杂。
寻找某个数据结构时,如果在Cache中能够找到(这种情况称为cache 命中),这的确很不错。但是如果没有找到,则必须找出它,并且添加到Cache中去。
如果Cache空间已经用完则Linux必须决定哪一个结构将从其中抛弃,但是有可能这个要抛弃的数据就是Linux下次要使用的数据。 2.3.3 抽象接口Linux核心常将其接口抽象出来。
接口指一组以特定方式执行的子程序和数据结构的集合。例如,所有的网络设备驱动必须提供对某些特定数据结构进行操作的子程序。
通用代码可能会使用底层的某些代码。例如网络层代码是通用的,它得到遵循标准接口的特定设备相关代码的支持。
通常在系统启动时,底层接口向更高层接口注册(Register)自身。这些注册操作包括向链表中加入结构节点。
例如,构造进核心的每个文件系统在系统启动时将其自身向核心注册。文件/proc/filesysems中可以看到已经向核心注册过的文件系统。
注册数据结构通常包括指向函数的指针,以文件系统注册为例,它向Linux核心注册时必须将那些mount文件系统连接时使用的一些相关函数的地址传入。
转载请注明出处51数据库 » linuxkeyword