cftp同步
① AU3原碼怎麼實現與ftp伺服器同步文件
首先去下載個FTPEx.au3
給段源碼你研究吧
python">
#include<FTPEx.au3>
#include<Array.au3>
Local$path
$server='192.168.1.1';伺服器
$name='admin';用戶名
$pass='admin';密碼
$Port='21';埠
$path="c:a1鄉村";遠程路徑,FTP的路徑。
$RemoteDir=$path;遠程根路徑轉換,不用管它。
$LocalDir="D:存儲軟體au3進行中FTP同步實驗室1同步路徑";本地路徑,你想讓文件下載到哪裡?
$LocalDir=flocalDir($RemoteDir,$LocalDir);轉換首目錄,不用管
;~MsgBox(0,"$LocalDir",$LocalDir)
ftp($server,$name,$pass,$Port,$path,$RemoteDir)
Funcftp($server,$name,$pass,$Port,$path,$RemoteDir)
;說明:主要函數,搜索,下載
$Open=_FTP_Open('MyFTP');打開一個FTP會話
$Conn=_FTP_Connect($Open,$server,$name,$pass,0,$Port);連接到ftp伺服器
_FTP_DirSetCurrent($Conn,$path)
$aFile=_FTP_ListToArrayEx($Conn,0,0);列目錄(0=文件和目錄,1=目錄,2=文件)(格式0=mm/dd/yyyy,1=yyyy/mm/dd)
;~_ArrayDisplay($aFile)
;~MsgBox(0,"顯示","共("&$aFile[0][0]&")個")
;~MsgBox(0,"$aFile[$i][0個]文件名",$aFile[0][0])
For$i=1To$aFile[0][0]
If$aFile[$i][2]=16And$aFile[$i][0]<>"."And$aFile[$i][0]<>".."Then
;~$path=$path&$aFile[$i][0]&""
;~MsgBox(0,"$path",$path&$aFile[$i][0]&"",$RemoteDir)
ftp($server,$name,$pass,$Port,$path&$aFile[$i][0]&"",$RemoteDir)
EndIf
If$aFile[$i][0]<>"."And$aFile[$i][0]<>".."And$aFile[$i][2]<>16Then
;檢驗
;~MsgBox(0,"",$aFile[$i][0])
$fname=$aFile[$i][0];文件名
$sync=ftpsync($LocalDir,$RemoteDir,$path,$fname)
;~MsgBox(0,"是否存在文件返回信息",$sync)
;~If$fname="PiView.mdb"Then
;~MsgBox(0,"$sync",$sync[0]&@LF&$sync[1])
;~EndIf
Select
Case$sync[0]=1;未發現文件
$ftp_download=_FTP_FileGet($Conn,$path&$fname,$sync[1],False);下載文件(True=覆蓋False=不覆蓋(默認))
;~MsgBox(0,$path&$fname,$sync[1])
Case$sync[0]=2;發現有同名文件
$ftpsize=_FTP_FileGetSize($Conn,$path&$aFile[$i][0])
$localsize=FileGetSize($sync)
;~MsgBox(0,"大小對比",$ftpsize&"-"&$localsize)
If$ftpsize<>$localsizeThen
;~MsgBox(0,"大小對比不成功",$ftpsize&"-"&$localsize)
;~MsgBox(0,"大小對比不成功",$path&$aFile[$i][0]&"-"&$sync)
$ftp_download=_FTP_FileGet($Conn,$path&$fname,$sync[1],False)
;~MsgBox(0,"$ftp_download",$ftp_download)
EndIf
CaseElse
MsgBox(0,"意外錯誤","搜索失敗")
EndSelect
;~MsgBox(0,"次數",$aFile[$i][0])
EndIf
;~MsgBox(0,"顯示","名="&$aFile[$i][0]&@CRLF&$aFile[$i][1]&@CRLF&$aFile[$i][2]&@CRLF&$aFile[$i][3]&@CRLF&$aFile[$i][4]&@CRLF&$aFile[$i][5])
Next
;$aFile[$i][0個]文件名
;$aFile[$i][1]文件大小
;$aFile[$i][2]文件屬性
;$aFile[$i][3]文件修改日期-時間
;$aFile[$i][4]文件創作日期-時間
;$aFile[$i][5]文件通入日期-時間
$Ftpc=_FTP_Close($Open);關閉_FTP_Open打開的回話
EndFunc;==>ftp
;~FuncDownload
;~用途:下載一個FTP上的文件
;~$ftp_download=_FTP_FileGet($Conn,"111 est222.txt","e:au3_ftp est222.txt",False);下載文件(True=覆蓋False=不覆蓋(默認))
;~EndFunc;==>ftp
Funcftpsync($LocalDir,$RemoteDir,$path,$fname);本地路徑,遠程根路徑路徑,變化中的遠程路徑,要下載的文件名。
Local$loc12
$loc12=_ArrayCreate("0","0")
;~說明:位置錯誤返回0,失敗返回1,成功返迴路徑。主要用來判斷是否有相同的文件。
IfFileExists($LocalDir)Then;看看本地是否存在,要是不存在就創建一個。
Else
DirCreate($LocalDir)
EndIf
Local$len=StringLen($RemoteDir)
Local$len1=StringLen($path)
$New=StringRight($path,$len1-$len)
;~MsgBox(0,"$New",$New)
;~MsgBox(0,"$fname",$fname)
IfFileExists($LocalDir&$New)Then
Else
;創建目錄
DirCreate($LocalDir&$New)
EndIf
;~MsgBox(0,"需要判斷是否存在的文件",$LocalDir&$New&$fname)
IfFileExists($LocalDir&$New&$fname)Then
;判斷文件大小
$loc12[0]=2
$loc12[1]=$LocalDir&$New&$fname
;~Return$LocalDir&$New&$fname
;~MsgBox(0,"文件是否存在判定-是存在",$LocalDir&$New&$fname)
Else
;創建目錄下載文件
;~Return1
$loc12[0]=1
$loc12[1]=$LocalDir&$New&$fname
EndIf
Return$loc12
EndFunc;==>ftpsync
FuncflocalDir($RemoteDir,$LocalDir)
;~說明:創建首目錄
$LOG=StringSplit($RemoteDir,"")
If$LOG[0]<=1Then;如果呢~只有根目錄盤那就是C盤根目錄
Local$result=StringLeft($RemoteDir,1)
$LocalDir=$LocalDir&$result&"盤根目錄"
Return$LocalDir
Else;如果不是那遠程目錄的最後一個文件夾,便是根目錄的最後一個文件夾了。
$Loc1=$LOG[$LOG[0]-1]
$LocalDir=$LocalDir&$Loc1&""
Return$LocalDir
EndIf
EndFunc;==>flocalDir
② 求助,如何ftp和samba共用同一個目錄
FTP的目錄是可以自己選擇的,可以選擇C盤 D盤 E盤,也可以隨便選擇一個文件夾或者新建一個文件夾當做FTP文件夾。這個可以在搭建FTP伺服器的時候選擇路徑。
而使用SMB協議的話,需要右鍵選擇你需要的那個文件夾,點擊屬性設置為共享。你可以選擇用戶為everyone,這樣方便點。
按以上步驟即可實現FTP文件夾和SMB共享文件夾都是一個文件夾。
③ 如何把OneNote筆記本同步到FTP伺服器
第一步:啟動IIS,並啟動IIS上的FTP服務。在默認的情況下,此時FTP伺服器已經搭建好,並且可以立即登錄,但是該FTP中沒有任何文件。
第二步:滑鼠右擊IIS中的「默認FTP站點螞納」項,選擇「屬性」菜單,
第三步:選擇「主目錄」的標簽,在FTP站點目錄的「本地路徑」處填上你要設置的共享文件路徑。默認情況下,此處的文件夾位置為「C:\Inetpub\Ftproot」,你如果臨時想改變共享目錄,隨時都可在此處修改,以後別人登錄你的FTP伺服器時顯示的文件列表就是在這個目錄中。
第三步:在「主目錄」的標簽處,還可設置FTP伺服器的文件訪問許可權,分別有讀取、寫入和日誌訪問,安全起見,這里的寫入許可權一般不選,保證匿名用戶不能隨意對文件進行操作。
第四步:設置登錄的用戶。如果願意提供「匿名」的訪問許可權,還需在「安全標簽」處選擇上「允許匿名連接」。此外,還可從Windows系統帳號中選擇FTP伺服器的特殊帳號,當然也可以自己任意設置晌賀用戶名和密碼。
第五步:在「消息」標簽處,有「歡迎」、「退出」和「最大連接數」3個輸入框,分別代表別人在登錄、退出時FTP伺服器上給出的提示信息,可根據悶謹沒自己的需要設置。此外,最大連接數是設置同時連接本地FTP的最大主機台數。
第六步:在「FTP站點」的標簽處設置FTP標識,包括說明、IP地址和埠,這里一般不需要改動,按照默認選擇即可。此外,在「C:\Winnt\System32\Logfiles」目錄中還可以看到連接上FTP的IP、時間等日誌信息。
此時,利用IE或者任何一款FTP的客戶端軟體即可登錄你架設好的FTP站點。
④ 一台電腦可以控制其餘兩台伺服器共享文件同步嗎 C#
C#一定要獲取兩台電腦的管理許可權,xisen的回答就是C#代碼,比較簡單。主要是許可權你要獲取,File.Copy(filepathB, filepathC);後面的地址許可權語句也應該加在裡面。前提C、B開通共享目錄。如果什麼工作都沒做,那就時能靠兩台電腦自己響應事件了
⑤ C# 多FTP伺服器 上傳文件時,文件同步。
上傳到A伺服器上之後你也可以從A上在分發到其他伺服器或者再將A做客戶端上傳到B和C
⑥ ftp是指的什麼
FTP(File Transfer Protocol,文件傳輸協議) 是 TCP/IP 協議組中的協議之一。FTP協議包括兩個組成部分,其一為FTP伺服器,其二為FTP客戶端。
其中FTP伺服器用來存儲文件,用戶可以使用FTP客戶端通過FTP協議訪問位於FTP伺服器上的資源。在開發網站的時候,通常利用FTP協議把網頁或程序傳到Web伺服器上。此外,由於FTP傳輸效率非常高,在網路上傳輸大的文件時,一般也採用該協議。
(6)cftp同步擴展閱讀
FTP工作原理:
與許多互聯網應用一樣,FTP服務也是一個客戶機用反務器系統(C/S)。用戶通過一個支持FTP協議的客戶端程序,連接到遠程主機上的FTP伺服器程序。用戶通過客戶端程序向伺服器程序發出命令,伺服器程序執行用戶所發出的命令,並將執行的結果返回到客戶端。
以文件下載為例,當啟動FTP客戶端程序從遠程計算機下載文件時,事實上啟動了兩個程序:一個本機上的FTP客戶端程序,它向FTP伺服器提出拷下載文件的請求;
另一個是啟動了遠程計算機的上的FTP伺服器程序,它響應你的請求並將指定的文件傳送到你的計算機中。目前,FTP的應用軟體有很多,如伺服器端的有Server-U、FileZilla等,客戶端的有CuteFtp 、 FlashFTP等,極大地方便了用戶的使用。
⑦ win2003系統下 FreeFileSync v8.1 如何通過sftp將需要備份的文件上傳到ftp伺服器進行備份。
默認的sublime text是沒有這個sftp連接功能的,這只是一個文本編輯器,相當於windows下的txt,所以要先裝上插件:
安裝Sublime Text 2插件的方法:
1.直接安裝
安裝Sublime text 2插件很方便http://www.uuudown.com/,可以直接下載安裝包解壓縮到Packages目錄
(菜單->preferences->packages)。
2.使用Package Control組件安裝,下載這個方法要先安裝Package Control,我就是用這個方法安裝的。
先安裝package control組件,然後直接在線安裝。
1) 按Ctrl+`調出console, 粘貼以下代碼到底部命令行並回車:
import urllib2,os;pf='Package Control.sublime-package';ipp=sublime.installed_packages_path();os.makedirs(ipp) if not os.path.exists(ipp) else None;open(os.path.join(ipp,pf),'wb').write(urllib2.urlopen('http://sublime.wbond.net/'+pf.replace(' ','%20')).read())
2)重啟Sublime Text 2。
如果在Perferences->package settings中看到package control這一項,則安裝成功。
3)用Package Control安裝插件的方法:
按下Ctrl+Shift+P調出命令面板
輸入install選擇下面提示的 Install Package選項並回車,然後輸入SFTP,下拉列表中會出現一些相關的插件,選中sftp進行安裝就行了,裝好後還需配置如下:選菜單欄中的File->SFTP/FTP->Set up Server,然後出現一個配置窗口如下,
連接成功的話會有在sublime的底部如下顯示,這樣鏈接成功了。。。
按下Ctrl+Shift+P調出命令面板
選中sftp進行安裝就行了,裝好後還需配置如下:
選菜單欄中的File->SFTP/FTP->Set up Server,然後出現一個配置窗口如下,
注意是ftp連接的話,要將sftp改成ftp,然後設置主機名,密碼,埠就行了,ftp的埠是21。
連接成功的話會有在sublime的底部如下顯示,這樣鏈接成功了。。。
下面介紹將一個項目上傳:
在工具欄中點擊Project - Add Folder to Project...,選擇項目的文件夾。這樣左側會出現project文件夾,右鍵project,選擇FTPSync - Setup FTPSync in this folder,之後會出來一個配置文件sftp-config.json,對配置文件進行修改,代碼如下:
[php] view plain
{
// The tab key will cycle through the settings when first created
// Visit http://wbond.net/sublime_packages/sftp/settings for help
// sftp, ftp or ftps
"type": "ftp",
"save_before_upload": true,
"upload_on_save": false,
"sync_down_on_open": false,
"sync_skip_deletes": false,
"confirm_downloads": false,
"confirm_sync": true,
"confirm_overwrite_newer": false,
"host": "wangshangyou.com",
"user": "",
"password": "",
//"port": "22",
"remote_path": "/",
"ignore_regexes": [
"\\.sublime-(project|workspace)", "sftp-config(-alt\\d?)?\\.json",
"sftp-settings\\.json", "/venv/", "\\.svn", "\\.hg", "\\.git",
"\\.bzr", "_darcs", "CVS", "\\.DS_Store", "Thumbs\\.db", "desktop\\.ini"
],
//"file_permissions": "664",
//"dir_permissions": "775",
//"extra_list_connections": 0,
"connect_timeout": 30,
//"keepalive": 120,
//"ftp_passive_mode": true,
//"ssh_key_file": "~/.ssh/id_rsa",
//"sftp_flags": ["-F", "/path/to/ssh_config"],
//"preserve_modification_times": false,
//"remote_time_offset_in_hours": 0,
//"remote_encoding": "utf-8",
//"remote_locale": "C",
}
在project目錄結構中選擇文件右鍵上傳,或者在命令輸入框中輸入命令。
這樣就完成了。
主要快捷鍵列表:
Ctrl+L 選擇整行(按住-繼續選擇下行)
Ctrl+KK 從游標處刪除至行尾
Ctrl+Shift+K 刪除整行
Ctrl+Shift+D 復制游標所在整行,插入在該行之前
Ctrl+J 合並行(已選擇需要合並的多行時)
Ctrl+KU 改為大寫
Ctrl+KL 改為小寫
Ctrl+D 選詞 (按住-繼續選擇下個相同的字元串)
Ctrl+M 游標移動至括弧內開始或結束的位置
Ctrl+Shift+M 選擇括弧內的內容(按住-繼續選擇父括弧)
Ctrl+/ 注釋整行(如已選擇內容,同「Ctrl+Shift+/」效果)
Ctrl+Shift+/ 注釋已選擇內容
Ctrl+Z 撤銷
Ctrl+Y 恢復撤銷
Ctrl+M 游標跳至對應的括弧
Alt+. 閉合當前標簽
Ctrl+Shift+A 選擇游標位置父標簽對兒
Ctrl+Shift+[ 折疊代碼
Ctrl+Shift+] 展開代碼
Ctrl+KT 折疊屬性
Ctrl+K0 展開所有
Ctrl+U 軟撤銷
Ctrl+T 詞互換
Tab 縮進 自動完成
Shift+Tab 去除縮進
Ctrl+Shift+↑ 與上行互換
Ctrl+Shift+↓ 與下行互換
Ctrl+K Backspace 從游標處刪除至行首
Ctrl+Enter 游標後插入行
Ctrl+Shift+Enter 游標前插入行
Ctrl+F2 設置書簽
F2 下一個書簽
Shift+F2 上一個書簽
⑧ PHP跨域上傳的幾種方法
方法一:
文件夾:/home/web/attachments
虛擬二級目錄到/home/web/zxsv/下(支持同區域網的伺服器)
這樣多個子域名進行上傳的設計時,只需要attachments目錄映射為相關的域名的二級目錄,這樣就可實現多個子域名共享一個附件伺服器了,這種方法最好是用區域網中的附件伺服器,這樣流量是分開的,當然訪問附件的域名是apache,ngixn,IIS等的虛擬二級目錄就不說了,好處是現有程序不做任何修改,唯一壞處就是兩台伺服器必須在一個區域網中,當然你用單台也就沒這個問題了
方法二:FTP同步更新
PHP是支持FTP的,給個FTP類裡面(不是我寫的,只是加了個建立多級目錄),自己看著辦吧,上傳後調用FTP類,同步到FTP伺服器中,好處是現有程序只需要在上傳那段加上FTP上傳就行了,壞處就是一定要支持FTP
<?php
$ftp=new Ftp;
//print_r($ftp->nlist(」"));
$ftp->makedir(」3″);
//$ftp->put(」comment.php」,」1.txt」);
$ftp->bye();
//R FTP 處理;
class ftp {
var $ftpUrl = 『www.zxsv.com』;
var $ftpUser = 『zxsv』;
var $ftpPass = 『111111′;
var $ftpDir = 『/zxsv/』;
var $ftpR = 」; //R ftp資源;
var $status = 」;
//R 1:成功;2:無法連接ftp;3:用戶錯誤;
function ftp() {
if ($this->ftpR = ftp_connect($this->ftpUrl, 21)) {
if (ftp_login($this->ftpR, $this->ftpUser, $this->ftpPass)) {
if (!empty($this->ftpDir)) {
ftp_chdir($this->ftpR, $this->ftpDir);
}
ftp_pasv($this->ftpR, true);//R 啟用被動模式;
$status = 1;
} else {
$status = 3;
}
} else {
$status = 2;
}
}
//R 切換目錄;
function cd($dir) {
return ftp_chdir($this->ftpR, $dir);
}
//建立目錄
function mkdir($dir){
return ftp_mkdir($this->ftpR, $dir);
}
function makedir($dir) {
if(!$dir) return 0;
$dir = str_replace( 「\\」, 「/」, $dir );
$mdir = 「」;
foreach(explode( 「/」, $dir ) as $val ) {
$mdir .= $val.」/」;
if( $val == 「..」 || $val == 「.」 ) continue;
if(!@mkdir($mdir)){
echo 「創建目錄 [".$mdir."]失敗.」;
//exit;
}
}
return true;
}
//刪除目錄
function rmdir($dir){
return ftp_rmdir($this->ftpR, $dir);
}
//R 返回當前路勁;
function pwd() {
return ftp_pwd($this->ftpR);
}
//R 上傳文件;
function put($localFile, $remoteFile = 」) {
if ($remoteFile == 」) {
$remoteFile = end(explode(』/', $localFile));
}
$res = ftp_nb_put($this->ftpR, $remoteFile, $localFile, FTP_BINARY);
print_r($res);
while ($res == FTP_MOREDATA) {
$res = ftp_nb_continue($this->ftpR);
}
if ($res == FTP_FINISHED) {
return true;
} elseif ($res == FTP_FAILED) {
return false;
}
}
//R 下載文件;
function get($remoteFile, $localFile = 」) {
if ($localFile == 」) {
$localFile = end(explode(』/', $remoteFile));
}
if (ftp_get($this->ftpR, $localFile, $remoteFile, FTP_BINARY)) {
$flag = true;
} else {
$flag = false;
}
return $flag;
}
//R 文件大小;
function size($file) {
return ftp_size($this->ftpR, $file);
}
//R 文件是否存在;
function isFile($file) {
if ($this->size($file) >= 0) {
return true;
} else {
return false;
}
}
//R 文件時間
function fileTime($file) {
return ftp_mdtm($this->ftpR, $file);
}
//R 刪除文件;
function unlink($file) {
return ftp_delete($this->ftpR, $file);
}
function nlist($dir = 『/service/resource/』) {
return ftp_nlist($this->ftpR, $dir);
}
//R 關閉連接;
function bye() {
return ftp_close($this->ftpR);
}
}
?>
⑨ 如何設置,能使本機某個文件夾的文件和伺服器共享文件夾里的對應的文件在每天11點做一次同步
網站文件的同步
在這里用到的主要工具就是FTP,網站文件同步分
兩種情況,一種是本地到遠程,一種是遠程到遠程
(FXP)!第一種不用說了,第二種遠程到遠程即FXP
,支持它的軟體也很多,但是真正適合多網站同步
鏡像的卻不多!
下面我介紹幾個我認為不錯的軟體!
1.首先我要推薦的是國產的FTP軟體」網路傳神
」,功能非常強大,特別是在網站的同步鏡像方面
,可惜的是,這款非常經典的軟體已經不再更新了
,最後更新時間是2003年3月,最後一個版本是3.1
2!雖然如此還是非常好用的!下面是一段官方的
簡介:
網路傳神完全吸收了Cuteftp和UpdataNow的全部
功能,並且增加了其他軟體沒有的多項功能:支
持網站互傳;支持網站同步(UPDATANOW);支持
後台上傳(多線程上傳多個文件);可同時打開多
個站點;多站點計劃上傳功能,支持鏡像站點;
支持宏操作支持計劃操作;支持文件高級比較上
傳;支持目錄隱藏過濾(為用ForntPage作主頁
的朋友帶來福音);伺服器自動識別功能;資源
管理器瀏覽方式;可以自定義命令;支持RFC959
標准具有更好的穩定性;完備的信息返回機制及
錯誤監控機制完整的中文幫助。
2.第二款是由ReGet同一開發公司製作的專用於
網站同步的軟體」WebSynchronizer」,用這款軟
件,你才會體驗到網站同步的方便快捷,簡單容易
.最新版本是1.3.62,網上能找到XX的最後版本是
1.1版!下面是一段簡介:
檔案同步化工具-WebSynchronizer,由知名續傳
軟體ReGet之軟體出版公司所推出,是網站同步
化、檔案鏡像、檔案備份的絕佳工具,可以執行
下列主要工作:1)本機資料夾及遠程資料夾的同
步化;2)兩台遠程計算機中的資料夾同步化;3)
兩個本機資料之同步化。
3.其他還有一些軟體如同步快梭(AutoSyncFTP),
也能實現簡單的網站同步,不過,這款軟體非常不
穩定,而且2001年就已經停止開發.所以,不用考
慮了!還有上次有朋友提到的SiteMirro,由於網
上找不到可以用的版本,所以沒有辦法測試!
網路傳神網站同步鏡像使用傻瓜指南
上次在網路技術版已經發過一個簡單的使用方法
介紹,如果嫌我羅嗦(o(>_<)o),大家可以參考那
篇文章:
http://bbs.et8.net/bbs/showthread.php?t=65
0129
第一次運行網路傳神的時候,它會讓你選擇」完
全模式」和」啟動模式」,要使用網站同步必須
選擇」完全模式」.
進入主界面:你會發現這個軟體非常像FlashGet,
要使用網站同步功能,點擊軟體左下角的」FTP客
戶端」.
現在你要做的就是添加你的鏡像母站和需要鏡像
的網站:文件->站點管理,在裡面添加你需要同步
的幾個的FTP伺服器,下面我將介紹具體設置(主
要是鏡像母站的設置)
母站設置最重要的地方就是」比較目錄(網站同
步)」:
1.拖動傳送
就是手動拖動傳送時候的傳送方式,非拖動方式
不受影響,因為母站的更新基本上是從本地目錄
進行的,所以建議這里選擇第二項」只上傳不同
的文件」,鏡像站點這里可以忽略
2.磁碟比較設置
這個功能非常有用,可以通過文件長度和文件日
期進行文件差異對比.
你還可以設置本地目錄過濾和伺服器目錄過濾,
非常靈活!
好了,添加好母站和鏡像站之後,我們來設置同步
:
如果是添加鏡像站,則會跳出下面的母站選擇窗
口:
設置好多個鏡像站點之後,返回主界面就可以進
行網站同步了:
注意事項:
一般不要改動鏡像站點前面的「對鉤」標志,因
為鏡像站點同步的原理是「根據主站點的同步信
息更新鏡像站點」,如果景象站點沒有更新那麼
必須將該鏡像站點單獨同步。
注意一般應該「選項窗口」-〉「FTP客戶端」-
〉「計劃」中的「最大連接個數」和「最大線程
個數」一般不要改動保持為「1」。
如果同步時某個站點出錯同步沒有完全完成只需
按「計劃」窗口中的按鈕單獨執行某個站點的傳
送即可。
再介紹一下網站鏡像同步中必要的功能,定時同
步,這樣你就只要做好母站的更新,其他的讓網路
傳神幫你完成:
點擊設置:
進入網路傳神的選項設置窗口,選中FTP客戶端中
的定時同步
定時下載:在指定的時段內下載文件。
定時上傳:在指定的時段內用網站同步的方法進
行上傳。
開始時間:如果要使用定時方式必須設置此項,
在設置的時間中會自動開始所有設置為計劃的站
點。
停止時間:如果設置此項則當系統時間大於停止
時間時自動停止所有設置為計劃的站點。
注意:定時上傳種沒有「停止時間」選項,網站
同步完成後會自動停止,同時網站同步同一時間
只能運行一次。
網路傳神還有很多為便於同步鏡像設置的功能,
大家實際使用中去體會吧!
WebSynchronizer網站同步鏡像使用傻瓜指南
WebSynchronizer功能非常強大,不單單是網站同
步,還可以進行本地目錄同步,本地到遠程同步,
功能方面遠勝過傳神,不過,國內好像沒有漢化版
,對於一些對英文感冒的朋友用起來會不太舒服,
希望CCF里的漢化高手能將他中文化!
開始運行程序,老外的軟體就是智能,一打開這個
軟體就會有一個同步向導跳出來!
在這里,你也看出來了吧,這個軟體只支持兩個目
錄間的同步.不過,我們可以創建多個項目來解決
這個問題!具體我在後面介紹!這里,我們來看看
如何建立兩個遠程目錄的同步!
選擇第二項,進入下一個選擇框:
網站同步當然是選擇第一項了!再進入下一步,要
你選擇同步的第一個伺服器,建議在這里servers
list,先編輯好需要同步的幾個FTP
同步方式設置說明:
第一項的意思是:上傳下載所有改變的文件
第二項的意思是:不改變文件夾內容,只下載新的
文件
點擊下一步進行第二個伺服器設置,方法和第一
個一樣!
設置完成後,你還可以修改任務名稱!
我覺得這點就是這個軟體非常優秀的地方,以任
務的方式進行管理.非常方便!
OK,現在我們就可以看到他的主界面了!
還有一點要提,他的計劃任務更能也很強大,在這
里我就不再多說了!用過才知道他的強大!
有朋友會說,我要進行兩個以上的網站同步怎麼
辦?
很簡單,再多建幾個任務就可以了,要鏡像多少網
站都沒有問題!
這個軟體的網站同步鏡像可以非常靈活,比如可
以本地-遠程,然後再遠程-遠程!或者本地-遠程1
,本地-遠程2,遠程1-遠程2,任何情形下的同步都
可以完成!
資料庫同步操作指南
說完了文件同步,我們再來探討一下資料庫同步!
這里我主要教大家兩種最常用的資料庫的同步方
法!
Mysql
MySQL數據同步主要有三種方式:
1.利用MySQL自身的資料庫同步功能
2.利用MySQL資料庫的特性(資料庫存在固頂目錄
,並且以文件形式存儲),進行資料庫目錄同步以
達到數據同步目的
3.利用專用的MySQL資料庫同步軟體
1.利用MySQL自身的資料庫同步功能(下面參考自
網上的文章,寫的非常詳細了)
MySQL從3.23.15版本以後提供資料庫復制功能。
利用該功能可以實現兩個資料庫同步,主從模式
,互相備份模式的功能.
資料庫同步復制功能的設置都在mysql的設置文
件中體現。mysql的配置文件(一般是my.cnf)
,在unix環境下在/etc/mysql/my.cnf或者在mys
ql用戶的home目錄下的my.cnf。
windows環境中,如果c:根目錄下有my.cnf文件
則取該配置文件。當運行mysql的winmysqladmin
.exe工具時候,該工具會把c:根目錄下的my.cnf
命名為mycnf.bak。並在winnt目錄下創建my.ini
。mysql伺服器啟動時候會讀該配置文件。所以
可以把my.cnf中的內容拷貝到my.ini文件中,用
my.ini文件作為mysql伺服器的配置文件。
設置方法:
設置範例環境:
操作系統:window2000professional
mysql:4.0.4-beta-max-nt-log
Aip:10.10.10.22
Bip:10.10.10.53
A:設置
1.增加一個用戶最為同步的用戶帳號:
GRANTFILEON*.*TObackup@'10.10.10.53'ID
ENTIFIEDBY『1234』
2.增加一個資料庫作為同步資料庫:
createdatabasebackup
B:設置
1.增加一個用戶最為同步的用戶帳號:
GRANTFILEON*.*TObackup@'10.10.10.22'ID
ENTIFIEDBY『1234』
2.增加一個資料庫作為同步資料庫:
createdatabasebackup
主從模式:A->B
A為master
修改Amysql的my.ini文件。在mysqld配置項
中加入下面配置:
server-id=1
log-bin
#設置需要記錄log可以設置log-bin=c:mysq
lbakmysqllog設置日誌文件的目錄,
#其中mysqllog是日誌文件的名稱,mysql將
建立不同擴展名,文件名為mysqllog的幾個日誌
文件。
binlog-do-db=backup#指定需要日誌的數據
庫
重起資料庫服務。
用showmasterstatus命令看日誌情況。
B為slave
修改Bmysql的my.ini文件。在mysqld配置項
中加入下面配置:
server-id=2
master-host=10.10.10.22
master-user=backup#同步用戶帳號
master-password=1234
master-port=3306
master-connect-retry=60預設重試間隔60
秒
replicate-do-db=backup告訴slave只做bac
kup資料庫的更新
重起資料庫
用showslavestatus看同步配置情況。
注意:由於設置了slave的配置信息,mysql
在資料庫目錄下生成master.info
所以如有要修改相關slave的配置要先刪除
該文件。否則修改的配置不能生效。
雙機互備模式。
如果在A加入slave設置,在B加入master設
置,則可以做B->A的同步。
在A的配置文件中mysqld配置項加入以下設
置:
master-host=10.10.10.53
master-user=backup
master-password=1234
replicate-do-db=backup
master-connect-retry=10
在B的配置文件中mysqld配置項加入以下設
置:
log-bin=c:mysqllogmysqllog
binlog-do-db=backup
注意:當有錯誤產生時*.err日誌文件。同
步的線程退出,當糾正錯誤後要讓同步機制進行
工作,運行slavestart
重起AB機器,則可以實現雙向的熱備。
測試:
向B批量插入大數據量表AA(1872000)條
A資料庫每秒鍾可以更新2500條數據。
2.資料庫目錄同步,方法和文件同步一樣,設置好
需要同步的兩個資料庫目錄就可以了!
缺點很明顯,數據同步只能單向進行,可以作為備
份方案
3.用專用的MySQL同步軟體進行同步
這方面的軟體有SQLBalance和MyReplicator,優
點是方便直觀,還有很多爭強功能!
缺點和2一樣,只能單項同步!
當然你也可以修改鏡像網站的程序為提交數據到
母資料庫,讀取則在當前鏡像下的數據,不過,修
改起來麻煩!普通用戶修改也非常難!呵呵,大家
了解一下就可以!給大家一個思路!有能力的朋友
可以試試阿!
4.關於MySQL論壇的數據同步
由於數據來源的不可控制(不好表達),論壇數據
是實時的,而且還要考慮來自鏡像論壇的數據,如
何實現鏡像論壇與母論壇數據同步呢?
用1中介紹的MySQL自帶的資料庫同步功能互相備
份模式就可以實現的!
不過,具體的應用我沒有測試!穩定性不敢保證!
有能力的朋友推薦用下面這種思路來同步,相對
來說減少點效率,但能減少發生的錯誤!
比如鏡像論壇數據同步:
1.母論壇和鏡像論壇的數據全寫在母論壇資料庫
里,主從模式,讀取只在本地讀取,這個需要修改
程序!
2.每次寫數據,都同時提交到兩個資料庫中,安全
,但是效率很差,也得修改程序!
MSSQL
MSSQL數據同步利用資料庫復制技術實現數據同
步更新(來自網路,也是非常完美的教程)
復制的概念
復制是將一組數據從一個數據源拷貝到多個數據
源的技術,是將一份數據發布到多個存儲站點上
的有效方式。使用復制技術,用戶可以將一份數
據發布到多台伺服器上,從而使不同的伺服器用
戶都可以在許可權的許可的范圍內共享這份數據。
復制技術可以確保分布在不同地點的數據自動同
步更新,從而保證數據的一致性。
SQL復制的基本元素包括
出版伺服器、訂閱伺服器、分發伺服器、出版物
、文章
SQL復制的工作原理
SQLSERVER主要採用出版物、訂閱的方式來處理
復制。源數據所在的伺服器是出版伺服器,負責
發表數據。出版伺服器把要發表的數據的所有改
變情況的拷貝復制到分發伺服器,分發伺服器包
含有一個分發資料庫,可接收數據的所有改變,
並保存這些改變,再把這些改變分發給訂閱服務
器
SQLSERVER復制技術類型
SQLSERVER提供了三種復制技術,分別是:
1、快照復制(呆會我們就使用這個)
2、事務復制
3、合並復制
只要把上面這些概念弄清楚了那麼對復制也就有
了一定的理解。接下來我們就一步一步來實現復
制的步驟。
第一先來配置出版伺服器
(1)選中指定[伺服器]節點
(2)從[工具]下拉菜單的[復制]子菜單中選擇[發
布、訂閱伺服器和分發]命令
(3)系統彈出一個對話框點[下一步]然後看著提
示一直操作到完成。
(4)當完成了出版伺服器的設置以後系統會為該
伺服器的樹形結構中添加一個復制監視器。同時
也生成一個分發資料庫(distribution)
第二創建出版物
(1)選中指定的伺服器
(2)從[工具]菜單的[復制]子菜單中選擇[創建和
管理發布]命令。此時系統會彈出一個對話框
(3)選擇要創建出版物的資料庫,然後單擊[創建
發布]
(4)在[創建發布向導]的提示對話框中單擊[下一
步]系統就會彈出一個對話框。對話框上的內容
是復制的三個類型。我們現在選第一個也就是默
認的快照發布(其他兩個大家可以去看看幫助)
(5)單擊[下一步]系統要求指定可以訂閱該發布
的資料庫伺服器類型,SQLSERVER允許在不同的
資料庫如ORACLE或ACCESS之間進行數據復制。但
是在這里我們選擇運行"SQLSERVER2000"的數據
庫伺服器
(6)單擊[下一步]系統就彈出一個定義文章的對
話框也就是選擇要出版的表
(7)然後[下一步]直到操作完成。當完成出版物
的創建後創建出版物的資料庫也就變成了一個共
享資料庫。
第三設計訂閱
(1)選中指定的訂閱伺服器
(2)從[工具]下拉菜單中選擇[復制]子菜單的[請
求訂閱]
(3)按照單擊[下一步]操作直到系統會提示檢查S
QLSERVER代理服務的運行狀態,執行復制操作的
前提條件是SQLSERVER代理服務必須已經啟動。
(4)單擊[完成]。完成訂閱操作。
完成上面的步驟其實復制也就是成功了。但是如
何來知道復制是否成功了呢?這里可以通過這種
方法來快速看是否成功。展開出版伺服器下面的
復制——發布內容——右鍵發布內容——屬性—
—擊活——狀態然後點立即運行代理程序接著點
代理程序屬性擊活調度把調度設置為每一天發生
,每一分鍾,在0:00:00和23:59:59之間。
接下來就是判斷復制是否成功了打開C:/Program
Files/MicrosoftSQLServer/MSSQL/REPLDATA/un
c/XIAOWANGZI_database_database下面看是不是
有一些以時間做為文件名的文件夾差不多一分中
就產生一個。要是你還不信的話就打開你的數據
庫看在訂閱的伺服器的指定訂閱資料庫下看是不
是看到了你剛才所發布的表—
一個手工同步的方案
--定時同步伺服器上的數據
--例子:
--測試環境,SQLServer2000,遠程伺服器名:xz,
用戶名為:sa,無密碼,測試資料庫:test
--伺服器上的表(查詢分析器連接到伺服器上創
建)
createtable[user](idintprimarykey,numberva
rchar(4),namevarchar(10))
go
--以下在區域網(本機操作)
--本機的表,state說明:null表示新增記錄,1表
示修改過的記錄,0表示無變化的記錄
ifexists(select*fromdbo.sysobjectswhereid=
object_id(N'[user]')andOBJECTPROPERTY(id,N
'IsUserTable')=1)
droptable[user]
GO
createtable[user](idintidentity(1,1),numbe
rvarchar(4),namevarchar(10),statebit)
go
--創建觸發器,維護state欄位的值
createtriggert_stateon[user]
afterupdate
as
update[user]setstate=1
from[user]ajoininsertedbona.id=b.id
wherea.stateisnotnull
go
--為了方便同步處理,創建鏈接伺服器到要同步
的伺服器
--這里的遠程伺服器名為:xz,用戶名為:sa,無密
碼
ifexists(select1frommaster..sysserverswher
esrvname='srv_lnk')
execsp_dropserver'srv_lnk','droplogins'
go
execsp_addlinkedserver'srv_lnk','','SQLOLE
DB','xz'
execsp_addlinkedsrvlogin'srv_lnk','false',
null,'sa'
go
--創建同步處理的存儲過程
ifexists(select*fromdbo.sysobjectswhereid=
object_id(N'[dbo].[p_synchro]')andOBJECTPR
OPERTY(id,N'IsProcere')=1)
dropprocere[dbo].[p_synchro]
GO
createprocp_synchro
as
--setXACT_ABORTon
--啟動遠程伺服器的MSDTC服務
--execmaster..xp_cmdshell'isql/S"xz"/U"sa"
/P""/q"execmaster..xp_cmdshell''netstartms
dtc'',no_output"',no_output
--啟動本機的MSDTC服務
--execmaster..xp_cmdshell'netstartmsdtc',n
o_output
--進行分布事務處理,如果表用標識列做主鍵,用
下面的方法
--BEGINDISTRIBUTEDTRANSACTION
--同步刪除的數據
deletefromsrv_lnk.test.dbo.[user]
whereidnotin(selectidfrom[user])
--同步新增的數據
insertintosrv_lnk.test.dbo.[user]
selectid,number,namefrom[user]wherestateis
null
--同步修改的數據
updatesrv_lnk.test.dbo.[user]set
number=b.number,name=b.name
fromsrv_lnk.test.dbo.[user]a
join[user]bona.id=b.id
whereb.state=1
--同步後更新本機的標志
update[user]setstate=0whereisnull(state,1)
=1
--COMMITTRAN
go
--創建作業,定時執行數據同步的存儲過程
ifexists(SELECT1frommsdb..sysjobswherename
='數據處理')
EXECUTEmsdb.dbo.sp_delete_job@job_name='數
據處理'
execmsdb..sp_add_job@job_name='數據處理'
--創建作業步驟
declare@sqlvarchar(800),@dbnamevarchar(250
)
select@sql='execp_synchro'--數據處理的命令
,@dbname=db_name()--執行數據處理的資料庫名
execmsdb..sp_add_jobstep@job_name='數據處
理',
@step_name='數據同步',
@subsystem='TSQL',
@database_name=@dbname,
@command=@sql,
@retry_attempts=5,--重試次數
@retry_interval=5--重試間隔
--創建調度
EXECmsdb..sp_add_jobschele@job_name='數
據處理',
@name='時間安排',
@freq_type=4,--每天
@freq_interval=1,--每天執行一次
@active_start_time=00000--0點執行
go
⑩ rsync實現windows環境下的數據同步(轉)
本文鏈接
https://www.cnblogs.com/loong-hon/p/13177422.html
四:客戶端同步服務端數據
客戶端安裝類似服務端一直下一步就行
rsync.exe -avz --progress --password-file=rsync.password [email protected]::testwin /cygdrive/d/ftpdata
rsync.exe -avz --progress --password-file=rsync.pass /cygdrive/d/ftpdata [email protected]::testwin
這隱清或個是把客戶端client文件同步到服務端server
注意:客戶端執行的時候要在客戶端的bin目錄下,還有一種方式可以配環境變數
同步的時候conf中灶伍配置的需要同步的目錄設置共享,然後將創建的testwin_rsyncy用戶也共享此文件夾。
D:cwRsync2in sync.exe -vrtopg --exclude=desktop.ini --exclude=Desktop.ini --exclude=Thumbs.db --exclude=RECYCLER --progress --password-file=etc/pwd.conf [email protected]::Documents/ /cygdrive/e/Documents
D:cwRsync2in sync.exe -vrtopg --exclude=desktop.ini --exclude=Desktop.ini --exclude=Thumbs.db --exclude=RECYCLER --progress --password-file=etc/pwd.conf /cygdrive/e/Documents [email protected]::Documents
#意思是
#執行 d:
sync_Kaiserin
sync.exe
# -vrtopg 這個是運行參數, 可以查看下邊的參數列表。
# -exclude=desktop.ini --exclude=Desktop.ini --exclude=Thumbs.db --exclude=RECYCLER 這些也是運行參數, 意思是把=號後邊的文件屏蔽掉,不做同步.
# --progress 在程序執行的時候屏幕窗口上顯示詳細的運作信息,例如整在同步那個文件,速度多少。
# -password-file=etc/pwd.conf 跟伺服器端一樣,指定密碼文件的路徑,以便在自動運行的時候不用手動來輸入.
# /cygdrive/e/Documents [email protected]::Documents本地文件夾 e: 盤上Documents所有的內容(路徑自己根據不情況進行修改)將和 服務端ip地址192.168.3.3 的 Documents 存儲目錄同步。
如果出現任何錯,最大一個可能第一是許可權沒弄好,目錄的,密碼文件的。
第二就是配置有誤,客戶端的沒跟伺服器的對應好,賬號或者存儲目錄名。
Rsync 的服務端配置里頭的儲存目錄不止寫一個的,還可以添加多個存放不同的文件夾或者不同的硬碟
-v, --verbose 詳細模式輸出
-q, --quiet 精簡輸出模式
-c, --checksum 打開校驗開關,強制對文件傳輸進行校驗
-a, --archive 歸檔模式,表示以遞歸方式傳輸文件,並保持所有文件屬性,等於-rlptgoD
-r, --recursive 對子目錄以遞歸模式處理
-R, --relative 使用相對路徑信息
-b, --backup 創建備份,也就是對於目的已經存在有同樣的文件名時,將老的正亂文件重新命名為~filename。可以使用--suffix選項來指定不同的備份文件前綴。
--backup-dir 將備份文件(如~filename)存放在在目錄下。
-suffix=SUFFIX 定義備份文件前綴
-u, --update 僅僅進行更新,也就是跳過所有已經存在於DST,並且文件時間晚於要備份的文件。(不覆蓋更新的文件)
-l, --links 保留軟鏈結
-L, ---links 想對待常規文件一樣處理軟鏈結
---unsafe-links 僅僅拷貝指向SRC路徑目錄樹以外的鏈結
--safe-links 忽略指向SRC路徑目錄樹以外的鏈結
-H, --hard-links 保留硬鏈結
-p, --perms 保持文件許可權
-o, --owner 保持文件屬主信息
-g, --group 保持文件屬組信息
-D, --devices 保持設備文件信息
-t, --times 保持文件時間信息
-S, --sparse 對稀疏文件進行特殊處理以節省DST的空間
-n, --dry-run現實哪些文件將被傳輸
-W, --whole-file 拷貝文件,不進行增量檢測
-x, --one-file-system 不要跨越文件系統邊界
-B, --block-size=SIZE 檢驗演算法使用的塊尺寸,默認是700位元組
-e, --rsh=COMMAND 指定使用rsh、ssh方式進行數據同步
--rsync-path=PATH 指定遠程伺服器上的rsync命令所在路徑信息
-C, --cvs-exclude 使用和CVS一樣的方法自動忽略文件,用來排除那些不希望傳輸的文件
--existing 僅僅更新那些已經存在於DST的文件,而不備份那些新創建的文件
--delete 刪除那些DST中SRC沒有的文件
--delete-excluded 同樣刪除接收端那些被該選項指定排除的文件
--delete-after 傳輸結束以後再刪除
--ignore-errors 及時出現IO錯誤也進行刪除
--max-delete=NUM 最多刪除NUM個文件
--partial 保留那些因故沒有完全傳輸的文件,以是加快隨後的再次傳輸
--force 強制刪除目錄,即使不為空
--numeric-ids 不將數字的用戶和組ID匹配為用戶名和組名
--timeout=TIME IP超時時間,單位為秒
-I, --ignore-times 不跳過那些有同樣的時間和長度的文件
--size-only 當決定是否要備份文件時,僅僅察看文件大小而不考慮文件時間
--modify-window=NUM 決定文件是否時間相同時使用的時間戳窗口,默認為0
-T --temp-dir=DIR 在DIR中創建臨時文件
--compare-dest=DIR 同樣比較DIR中的文件來決定是否需要備份
-P 等同於 --partial
--progress 顯示備份過程
-z, --compress 對備份的文件在傳輸時進行壓縮處理
--exclude=PATTERN 指定排除不需要傳輸的文件模式
--include=PATTERN 指定不排除而需要傳輸的文件模式
--exclude-from=FILE 排除FILE中指定模式的文件
--include-from=FILE 不排除FILE指定模式匹配的文件
--version 列印版本信息
--address 綁定到特定的地址
--config=FILE 指定其他的配置文件,不使用默認的rsyncd.conf文件
--port=PORT 指定其他的rsync服務埠
--blocking-io 對遠程shell使用阻塞IO
-stats 給出某些文件的傳輸狀態
--progress 在傳輸時現實傳輸過程
--log-format=formAT 指定日誌文件格式
--password-file=FILE 從FILE中得到密碼
--bwlimit=KBPS 限制I/O帶寬,KBytes per second
-h, --help 顯示幫助信息
參考地址: https://www.iteye.com/blog/netsky-cheng-1187298
相關鏈接
簡單兩步實現 rsync 自動同步文件免密
https://blog.csdn.net/ot512csdn/article/details/107613205
Rsync 數據同步工具應用指南
https://zhuanlan.hu.com/p/40022680