私はhttp://github.com/dutchcoders/goftpを使ってFTP経由でファイルを送信しました。それは正常に動作しますが、ファイルをアップロードしてそのファイル情報を取得したいとき(同時に)、うまくいきません!golang FTPでアップロードして同時にFTPの進行を取得
fileName := "sth"
var err error
var ftp *goftp.FTP
if ftp, err = goftp.Connect("serverip:port"); err != nil {
fmt.Println(err)
}
defer ftp.Close()
config := tls.Config{
InsecureSkipVerify: true,
ClientAuth: tls.RequestClientCert,
}
if err = ftp.AuthTLS(config); err != nil {
// log.Println("1", err)
}
if err = ftp.Login("userName", "pass"); err != nil {
log.Println("2", err)
}
//
if err = ftp.Cwd("/home/myDir/"); err != nil {
log.Println("3", err)
}
var file *os.File
if file, err = os.Open(fileName); err != nil {
log.Println("6", err)
}
defer file.Close()
fmt.Println("start")
go func() {
fmt.Println("first")
nmp := ftp.Stor(fileName, file)
if nmp != nil {
log.Println("7", err)
} else {
fmt.Println("first is runung")
}
}()
go func() {
fmt.Println("second")
for {
files, nms := ftp.List(fileName)
if nms == nil {
fmt.Println(files)
}
time.Sleep(1 * time.Second)
}
}()
fmt.Println("end")
var mnmn string
fmt.Scan(&mnmn)
ftp.Storのfuncが実行されず、出力以下の私のコードを返します:
start end first second 2016/05/31 13:21:38 7 <nil> [] []
あなたは完全なメインを共有できますか?メインをブロックしていますか?それ以外の場合は、ルーチンを待つことはありません。 – khrm
@khrm私は自分の質問を編集しました! –
あなたはftpの2つの異なるインスタンスをとっておくことができます。その後、正常に動作します。 – khrm