linux學習-linux配置文件出去註釋行

1、使用grep -v “^#”  來去掉註釋行,其中:-v  就是取相反的   ^# 表示註解行

  eg. grep -v “^#” /etc/vsftpd/vsftpd.conf (也可以使用“>”來重寫配置文件)

  2、有時也會連同空行壹起去掉,使用管道符來完成(^$表示空行  )

  eg. grep -v “^#”  httpd.conf | grep -v “^$”  >> vsftpd.conf

  上面用了 2次 grep 過濾命令 ,也就是把空行和註解行過濾掉,再把剩下的內容追加保存為原

  來的配置文件 vsftpd.conf  這個時候就文件裏的內容就沒有註解行和空行了,,,,

  提示: 對配置文件不熟悉的建議不要用這種方法,配置文件中的註解行還是有壹定的幫助的。

  另外,在更改配置文件時,建議先對配置文件做壹下備份:

  cp  -a  httpd.conf  httpd.conf.bak

Linux中如何創建靜態庫和動態庫

靜態庫在程序編譯時會被連接到目標代碼中,程序運行時將不再需要該靜態庫。

  動態庫在程序編譯時並不會被連接到目標代碼中,而是在程序運行是才被載入,因此在程序運行時還需要動態庫存在。

  程序1: hello.h

  #ifndef HELLO_H

  #define HELLO_H

  void hello(const char *name);

  #endif //HELLO_H

  程序2: hello.c

  #include <stdio.h>

  void hello(const char *name)

  {

  printf(“Hello %s!\n”, name);

  }

  程序3: main.c

  #include “hello.h”

  int main()

  {

  hello(“everyone”);

  return 0;

  }

  無論動態庫還是靜態庫都需要用到.o文件來生成,先編譯生成.o文件。

  # gcc -c hello.c

  1:創建靜態庫

  靜態庫文件名的命名規範是以lib為前綴,緊接著跟靜態庫名,擴展名為.a。例如:我們將創建的靜態庫名為myhello,則靜態庫文件名就是libmyhello.a。

  # ar cr libmyhello.a hello.o

  使用靜態庫:只需要在妳的源程序中加入包含妳所需要使用到的函數的聲明(即包含頭文件),然後在gcc生成目標文件時候指明靜態庫就OK了(除非妳包含的頭文件在/usr/include,庫文件在標準庫/usr/lib,/lib下,否則妳得顯示指明他們的路徑)

  # gcc -o hello main.c -L. -lmyhello

  # ./hello

  Hello everyone!

  刪除靜態庫文件運行./hello,程序正常運行,說明靜態庫公用函數已經鏈接到目標文件。

  2: 利用.o文件創建動態庫

  動態庫文件擴展名為.so。

  # gcc -shared -fPCI -o libmyhello.so hello.o

  動態庫的使用與靜態庫使用方式壹樣

  # gcc -o hello main.c -L. -lmyhello

  # ./hello

  ./hello: error while loading shared libraries: libmyhello.so: cannot open shared object file: No such file or directory

  哦!出錯了。快看看錯誤提示,原來是找不到動態庫文件libmyhello.so。程序在運行時,會在/usr/lib和/lib等目錄中查找需要的動態庫文件。若找到,則載入動態庫,否則將提示類似上述錯誤而終止程序運行。

  如何找到生成的動態庫有3種方式:

  1)把庫拷貝到/usr/lib和/lib目錄下。

  (2)在LD_LIBRARY_PATH環境變量中加上庫所在路徑。

  例如動態庫libhello.so在/home/example/lib目錄下:

  $export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/example/lib

  (3) 修改/etc/ld.so.conf文件,把庫所在的路徑加到文件末尾,並執行ldconfig刷新。這樣,加入的目錄下的所有庫文件都可見。

  當靜態庫和動態庫同名時, gcc命令將優先使用動態庫。

  函數庫分為靜態庫和動態庫兩種。

  靜態庫在程序編譯時會被連接到目標代碼中,程序運行時將不再需要該靜態庫。

  動態庫在程序編譯時並不會被連接到目標代碼中,而是在程序運行是才被載入,因此在程序運行時還需要動態庫存在。

  程序1: hello.h

  #ifndef HELLO_H

  #define HELLO_H

  void hello(const char *name);

  #endif //HELLO_H

  程序2: hello.c

  #include <stdio.h>

  void hello(const char *name)

  {

  printf(“Hello %s!\n”, name);

  }

  程序3: main.c

  #include “hello.h”

  int main()

  {

  hello(“everyone”);

  return 0;

  }

  無論動態庫還是靜態庫都需要用到.o文件來生成,先編譯生成.o文件。

  # gcc -c hello.c

  1:創建靜態庫

  靜態庫文件名的命名規範是以lib為前綴,緊接著跟靜態庫名,擴展名為.a。例如:我們將創建的靜態庫名為myhello,則靜態庫文件名就是libmyhello.a。

  # ar cr libmyhello.a hello.o

  使用靜態庫:只需要在妳的源程序中加入包含妳所需要使用到的函數的聲明(即包含頭文件),然後在gcc生成目標文件時候指明靜態庫就OK了(除非妳包含的頭文件在/usr/include,庫文件在標準庫/usr/lib,/lib下,否則妳得顯示指明他們的路徑)

  # gcc -o hello main.c -L. -lmyhello

  # ./hello

  Hello everyone!

  刪除靜態庫文件運行./hello,程序正常運行,說明靜態庫公用函數已經鏈接到目標文件。

  2: 利用.o文件創建動態庫

  動態庫文件擴展名為.so。

  # gcc -shared -fPCI -o libmyhello.so hello.o

  動態庫的使用與靜態庫使用方式壹樣

  # gcc -o hello main.c -L. -lmyhello

  # ./hello

  ./hello: error while loading shared libraries: libmyhello.so: cannot open shared object file: No such file or directory

  哦!出錯了。快看看錯誤提示,原來是找不到動態庫文件libmyhello.so。程序在運行時,會在/usr/lib和/lib等目錄中查找需要的動態庫文件。若找到,則載入動態庫,否則將提示類似上述錯誤而終止程序運行。

  如何找到生成的動態庫有3種方式:

  1)把庫拷貝到/usr/lib和/lib目錄下。

  (2)在LD_LIBRARY_PATH環境變量中加上庫所在路徑。

  例如動態庫libhello.so在/home/example/lib目錄下:

  $export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/example/lib

  (3) 修改/etc/ld.so.conf文件,把庫所在的路徑加到文件末尾,並執行ldconfig刷新。這樣,加入的目錄下的所有庫文件都可見。

  當靜態庫和動態庫同名時, gcc命令將優先使用動態庫。

輕松解決Linux系統grub錯誤

Linux在現在已經很強大了,導致Linux系統越來越受到電腦用戶的歡迎,於是很多人開始學習Linux時,學習時妳可能會遇到Linux系統grub常見錯誤問題,這裏將介紹Linux系統grub常見錯誤問題的解決方法,讓大家了解壹下。

  1:Filenamemustbeeitheranabsolutefilenameorblocklist

  解釋:1號錯誤表示文件名格式錯誤。在GRUB中要麽是以絕對路徑給出文件

  例子:

  grub>kernelvmlinuzroot=label=/

  Error1:Filenamemustbeeitheranabsolutepathnameorblocklist

  grub>

  2:Badfileordirectorytype

  解釋:2號錯誤表示命令期望的是壹個普通文件,但相應文件名的對象是壹個符號鏈接、目錄、FIFO

  例子:

  grub>kernel/testdirroot=LABEL=/

  Error2:Badfileordirectorytype

  grub>

  3:Badorcorruptdatawhiledecompressingfile

  解釋:3號錯誤表示解壓文件時發生錯誤。可能是因為這個文件被損壞了

  4:Badorincompatibleheaderincompressedfile

  解釋:4號錯誤表示壓縮文件的頭部格式不被兼容或者錯誤

  5:Partitiontableinvalidorcorrupt

  解釋:5號錯誤表示分區表無效或者被破壞。這是壹個不好的預兆

  6:Mismatchedorcorruptversionofstage1/stage2

  解釋:6號錯誤表示install命令發現stage1和stage2的頒布號不被兼容

  7:Loadingbelow1MBisnotsupported

  解釋:Thiserrorisreturnedifthelowestaddressinakernelisbelow

  the1MBboundary.TheLinuxzImageformatisaspecialcaseand

  canbehandledsinceithasafixedloadingaddressandmaximumsize

  8:Kernelmustbeloadedbeforebooting

  解釋:8號錯誤表示執行boot命令之前沒有先執行kernel命令

  9:Unknownbootfailure

  解釋:9號錯誤表示未知的引導錯誤

  10:UnsupportedMultibootfeaturesrequested

  解釋:10號錯誤表示請求Multibootheader所要求功能不被GRUB所支持。

  11:Unrecognizeddevicestring

  解釋:11號錯誤表示無法識別的設備字符串。

  例子:

  grub>roothd0

  Error11:Unrecognizeddevicestring

  grub>

  12:Invaliddevicerequested

  解釋:12號錯誤表示請求的設備無效

  例子:

  grub>root(hd2)

  Error21:Selecteddiskdoesnotexist

  grub>kernel/grub/grub.confroot=LABEL=/

  Error12:Invaliddevicerequested

  grub>

  13:Invalidorunsupportedexecutableformat

  解釋:13號錯誤表示無效或者無法識別的可執行格式

  例子:

  grub>kernel/grub/grub.confroot=LABEL=/

  Error13:Invalidorunsupportedexecutableformat

  grub>

  14:Filesystemcompatibilityerror,cannotreadwholefile

  解釋:14號錯誤表示文件系統兼容性錯誤,無法讀取整個文件

  15:Filenotfound

  解釋:請求的文件無法找到

  例子:

  grub>find/grub-noexist/grub.conf

  Error15:Filenotfound

  grub>

  16:Inconsistentfilesystemstructure

  解釋:16號錯誤表示不壹致的文件系統結構。可能是文件系統結構被破壞了。

  17:Cannotmountselectedpartition

  解釋:17號錯誤表示無法掛載指定分區。例如swap分區

  例子:

  grub>root(hd0,2)這是壹個swap分區

  Filesystemtypeunknown,partitiontype0x82

  grub>kernel/vmlinuz

  Error17:Cannotmountselectedpartition

  grub>