vsftpd使用方法小结、Linux安装JDK出现“NoClassDefFoundError: /Object”的解决方案、ubuntu 12.04安装jdk
vsftpd 是一個 UNIX 類操作系統上運行的服務器的名字,它可以運行在諸如 Linux, BSD, Solaris,HP-UX 以及 IRIX 上面。它支持很多其他的 FTP 服務器不支持的特征。比如:
- 非常高的安全性需求
- 帶寬限制
- 良好的可伸縮性
- 創建虛擬用戶的可能性
- IPv6支持
- 中等偏上的性能
- 分配虛擬 IP 的可能性
- 高速
一個例子就是 vsftpd 是在 chroot 模式下工作的,chroot 模式就是為程序(這里就是 vsftpd了)單獨指定一個新的目錄,它也就不能訪問那個目錄之外的程序和文件了 --- 所以這也稱為“被鎖上的”。一個可能被潛在的攻擊者破壞的FTP 服務器將被從系統的其他部分獨立開來,從而避免了更大的損失。
由于有了如此多的特性,其中 FTP 服務的安全性應該是最重要的,vsftpd 比其他 FTP 服務器更加優越。
1.安裝vsftpd?
直接從源里面安裝,easy?
安裝完畢后或許會自動生成一個帳戶"ftp",/home下也會增加一個文件夾。
如果沒有生成這個用戶的話可以手動來,生成了就不用了:
代碼: sudo useradd -m ftp
sudo passwd ftp
有"ftp"帳戶后還要更改權限
代碼: sudo chmod 777 /srv/ftp(注意:原日志是這么寫的,但是這句執行之后會有錯誤。應該是
sudo chmod 755 /srv/ftp)
在這個目錄下我建立一個文件夾專門保存需要共享的內容
2.配置文件
通過sudo gedit /etc/vsftpd.conf修改。
配置文件如下:
代碼: # cat /etc/vsftpd.conf
# 服務器以 standalong 模式運行,如果以 root 用戶直接啟動 vsftpd 進程,則必須。
# 注銷語句以 xinetd 方式運行
listen=YES # 上傳總開關(全局控制)
write_enable=YES # 接受匿名用戶,默認無密碼請求
anonymous_enable=YES # 接受本地用戶
local_enable=YES # 本地用戶上傳文件(包括目錄)的 umask
# 注意 vsftp 版本,某些舊版的該選項會被 chown_uploads/chown_username 二選項覆蓋
local_umask=022 # 允許匿名用戶上傳文件,配合 anon_umask,否則文件權限皆為默認的600,用戶上傳的文件不提供給任何匿名用戶下載
anon_upload_enable=YES # 匿名用戶上傳文件(包括目錄)的 umask
# 注意點同 local_umask
anon_umask=022 # 允許匿名用戶創建目錄,配合 anon_umask 實現目錄可寫,否則依我(aBiNg)看,實際用處很小
anon_mkdir_write_enable=YES # 允許匿名用戶刪除/重命名文件等操作
#anon_other_write_enable=YES # 為 YES 則進入目錄時顯示此目錄下由 message_file 選項指定的文本文件(默認為 .message)的內容
dirmessage_enable=YES # 使用上傳/下載日志,日志文件默認為 /var/log/vsftpd.log,可以通過 xferlog_file選項修改
xferlog_enable=YES # 使用 port 模式連接,并啟用 20 端口
connect_from_port_20=YES # 改變用戶上傳文件的所有者
#chown_uploads=YES
#chown_username=whoever
#xferlog_file=/var/log/vsftpd.log # 日志使用標準 xferlog 格式
#xferlog_std_format=YES # 用戶登陸后 idle 時間,超過設置超則被踢出服務器
#idle_session_timeout=600 # login 時的歡迎信息
ftpd_banner=Welcome to feifei FTP service. #deny_email_enable=YES
#banned_email_file=/etc/vsftpd.banned_emails # 若為 NO,則記錄在 chroot_list_file 選項所指定的文件(默認是/etc/vsftpd.chroot_list)中的用戶將被
# chroot 在登錄后所在目錄中,無法離開。如果為 YES,則所記錄的用戶將不被 chroot。
chroot_local_user=YES # 設置為 YES 則下面的控制有效
#chroot_list_enable=YES
#chroot_list_file=/etc/vsftpd.chroot_list #ls_recurse_enable=YES
secure_chroot_dir=/var/run/vsftpd
pam_service_name=vsftpd
rsa_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem
rsa_private_key_file=/etc/ssl/private/ssl-cert-snakeoil.key local_root=/srv/ftp
對了,更改配置后不要忘了重啟ftp服務??
代碼: sudo /etc/init.d/vsftpd restart
此外還有開啟關閉服務的命令
代碼: sudo /etc/init.d/vsftpd start
sudo /etc/init.d/vsftpd stop
這樣,就可以使用電腦的IP地址登陸這個ftp服務器了。
?
vsftpd我用了比較長的一段時間,感覺非常穩定,安全性高,就推薦給大家,給大家寫點有關限制方面的文章。請看下文介紹!
一、如何讓vsFTP服務器限制鏈接數,以及每個IP最大的鏈接數?
應該改vsFTPd服務器的配制文件vsftpd.conf,加入下面的兩行:
max_clients=數字
max_per_ip=數字
舉例:我想讓我的vsFTP最大支持鏈接數為100個,每個IP,最多能支持5個鏈接,所以我應該在vsftpd.conf中加上如下的兩行:
max_clients=100
max_per_ip=5
改好了配制文件,不要忘記啟動vsftp服務器。
二、如何限制傳輸速度?
anon_max_rate=數字
注:這是匿名的速度
local_max_rate=數字
注:這是vsFTP服務器上本地用戶的速度
注:這個數字的單位是bit,所以我們要計算一下。比如我想讓匿名用戶和vsFTP上的用戶都以100KB下載,所以這個數字應該是1024x100=102400
所以我們要在vsftpd.conf中加入下面的兩行
anon_max_rate=102400
local_max_rate=102400
通過閱讀上面的文章,我們不難看出vsftpd有許多小技巧,限制傳輸速度和鏈接點數是非常實用的功能,希望對你們有幫助!vi的常用命令 1、vi的基本概念
基本上vi可以分為三種狀態:
?? 分別是命令模式(command mode)
?? 插入模式(Insertmode)
?? 底行模式(last line mode)
1) 命令行模式command mode)
?? 控制屏幕光標的移動,字符、字或行的刪除,移動復制某區段及進入Insert mode下,或者到 last line mode。
2) 插入模式(Insert mode)
"i","a","o","r"
?? 只有在Insert mode下,才可以做文字輸入,按「ESC」鍵可回到命令行模式。
3) 底行模式(last line mode)
命令模式下按":"
?? 3,1>:/'查找字符' n? 或者 :?'查找字符' n
?? 3,2>:set nu 顯示行號
?? 3,3>:q!(退出不保存),:wq(保存并退出)
2、vi的基本操作
?? a) 進入vi
? ??? # vi mynewfile.txt ??
?? b) 切換至插入模式(Insert mode)編輯文件??
????
??????"i","a","o","r"
?? c) Insert 的切換
? 從當前插入模式切換到命令行模式按[ESC]即可
?? d) 退出vi及保存文件
?? : w filename (輸入 「w filename」將文章以指定的文件名filename保存)
?? : wq (輸入「wq」,存盤并退出vi)
?? : q! (輸入q!, 不存盤強制退出vi)
3、命令行模式(command mode)功能鍵
1). 插入模式
按「i」切換進入插入模式「insert mode」,按“i”進入插入模式后是從光標當前位
置開始輸入文件;
按「a」進入插入模式后,是從目前光標所在位置的下一個位置開始輸入文字;
按「o」進入插入模式后,是插入新的一行,從行首開始輸入文字。
2). 從插入模式切換為命令行模式
按「ESC」鍵。
3). 移動光標
vi可以直接用鍵盤上的光標來上下左右移動,但正規的vi是用小寫英文字母「h」、「
j」、「k」、「l」,分別控制光標左、下、上、右移一格。
按「ctrl」+「b」:屏幕往“后”移動一頁。
按「ctrl」+「f」:屏幕往“前”移動一頁。
按「ctrl」+「u」:屏幕往“后”移動半頁。
按「ctrl」+「d」:屏幕往“前”移動半頁。
按數字「0」:移到文章的開頭。
按「G」:移動到文章的最后。
按「$」:移動到光標所在行的“行尾”。
按「^」:移動到光標所在行的“行首”
按「w」:光標跳到下個字的開頭
按「e」:光標跳到下個字的字尾
按「b」:光標回到上個字的開頭
按「#l」:光標移到該行的第#個位置,如:5l,56l。
4). 刪除文字
「x」:每按一次,刪除光標所在位置的“后面”一個字符。
「#x」:例如,「6x」表示刪除光標所在位置的“后面”6個字符。
「X」:大寫的X,每按一次,刪除光標所在位置的“前面”一個字符。
「#X」:例如,「20X」表示刪除光標所在位置的“前面”20個字符。
「dd」:刪除光標所在行。
「#dd」:從光標所在行開始刪除#行
5). 復制
「yw」:將光標所在之處到字尾的字符復制到緩沖區中。
「#yw」:復制#個字到緩沖區
「yy」:復制光標所在行到緩沖區。
「#yy」:例如,「6yy」表示拷貝從光標所在的該行“往下數”6行文字。
「p」:將緩沖區內的字符貼到光標所在位置。注意:所有與“y”有關的復制命令都
必須與“p”配合才能完成復制與粘貼功能。
6). 替換
「r」:替換光標所在處的字符。
「R」:替換光標所到之處的字符,直到按下「ESC」鍵為止。
7). 回復上一次操作
「u」:如果您誤執行一個命令,可以馬上按下「u」,回到上一個操作。按多次“u”
可以執行多次回復。
8). 更改
「cw」:更改光標所在處的字到字尾處
「c#w」:例如,「c3w」表示更改3個字
9). 跳至指定的行
「ctrl」+「g」列出光標所在行的行號。
「#G」:例如,「15G」,表示移動光標至文章的第15行行首。
4、Last line mode下命令簡介
在使用「last line mode」之前,請記住先按「ESC」鍵確定您已經處于「command m
ode」下后,再按「:」冒號即可進入「last line mode」。
A) 列出行號
「set nu」:輸入「set nu」后,會在文件中的每一行前面列出行號。
B) 跳到文件中的某一行
「#」:「#」號表示一個數字,在冒號后輸入一個數字,再按回車鍵就會跳到該行了,
如輸入數字15,再回車,就會跳到文章的第15行。
C) 查找字符
「/關鍵字」:先按「/」鍵,再輸入您想尋找的字符,如果第一次找的關鍵字不是您想
要的,可以一直按「n」會往后尋找到您要的關鍵字為止。
「?關鍵字」:先按「?」鍵,再輸入您想尋找的字符,如果第一次找的關鍵字不是您想
要的,可以一直按「n」會往前尋找到您要的關鍵字為止。
D) 保存文件
「w」:在冒號輸入字母「w」就可以將文件保存起來。
E) 離開vi
「q」:按「q」就是退出,如果無法離開vi,可以在「q」后跟一個「!」強制離開vi。
「qw」:一般建議離開時,搭配「w」一起使用,這樣在退出的時候還可以保存文件。
5、vi命令列表
1、下表列出命令模式下的一些鍵的功能:
h
左移光標一個字符
l
右移光標一個字符
k
光標上移一行
j
光標下移一行
^
光標移動至行首
0
數字“0”,光標移至文章的開頭
G
光標移至文章的最后
$
光標移動至行尾
Ctrl+f
向前翻屏
Ctrl+b
向后翻屏
Ctrl+d
向前翻半屏
Ctrl+u
向后翻半屏
i
在光標位置前插入字符
a
在光標所在位置的后一個字符開始增加
o
插入新的一行,從行首開始輸入
ESC
從輸入狀態退至命令狀態
x
刪除光標后面的字符
#x
刪除光標后的#個字符
X
(大寫X),刪除光標前面的字符
#X
刪除光標前面的#個字符
dd
刪除光標所在的行
#dd
刪除從光標所在行數的#行
yw
復制光標所在位置的一個字
#yw
復制光標所在位置的#個字
yy
復制光標所在位置的一行
#yy
復制從光標所在行數的#行
p
粘貼
u
取消操作
cw
更改光標所在位置的一個字
#cw
更改光標所在位置的#個字
2、下表列出行命令模式下的一些指令
w filename
儲存正在編輯的文件為filename
wq filename
儲存正在編輯的文件為filename,并退出vi
q!
放棄所有修改,退出vi
set nu
顯示行號
/或?
查找,在/后輸入要查找的內容
n
與/或?一起使用,如果查找的內容不是想要找的關鍵字,按n或向后(與/聯用)或向前(
與?聯用)繼續查找,直到找到為止。
對于第一次用vi,有幾點注意要提醒一下:
1、用vi打開文件后,是處于「命令行模式(command mode)」,您要切換到「插入模式(
Insert mode)」才能夠輸入文字。切換方法:在「命令行模式(command mode)」下按一
下字母「i」就可以進入「插入模式(Insert mode)」,這時候你就可以開始輸入文字了
。
2、編輯好后,需從插入模式切換為命令行模式才能對文件進行保存,切換方法:按「ESC
」鍵。
3、保存并退出文件:在命令模式下輸入:wq即可!(別忘了wq前面的:)
Linux安裝JDK出現“NoClassDefFoundError: /Object”的解決方案
在RedHat?Linux上安裝jdk出現了一個莫名的錯誤
Error occurred during initialization of VM
java/lang/NoClassDefFoundError: java/lang/Object
辛苦google了一個小時,終于找到了解決方案
首先要確認的是環境變量的設置是否正確
相信大家都是很細心的,這方面如果有錯誤也會很容易發現
然而還有一個隱蔽的地方也會產生上述的錯誤
就是lib和jre/lib文件夾中的rt和tools是否是打包后的形式
如果發現rt.pack 和 tools.pack 那么多半問題就出在這里
解決方法也很簡單,只要將相應文件解壓成rt.jar 和 tools.jar
可以使用bin里面的unpack200工具
如:unpack200 rt.pack rt.jar
解壓后java -version應該就沒有問題了~~
ps:在 SUSE ? Linux上也同樣可以處理這樣的問題。ubuntu 12.04安裝jdk
在安裝之前,系統沒有任何jdk軟件,也就是說在終端執行
進入在存放jdk文件夾的當前目錄,將解壓好的jdk1.7.0_10文件夾用最高權限復移動到/usr/lib/jvm目錄里,此時即使沒有jvm目錄也可以執行如下命令,jvm文件夾將得到創建。
將系統默認的jdk修改過來
總結
以上是生活随笔為你收集整理的vsftpd使用方法小结、Linux安装JDK出现“NoClassDefFoundError: /Object”的解决方案、ubuntu 12.04安装jdk的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Hadoop的伪分布安装 hadoop
- 下一篇: Linux命令常用大全