1
나는 socketError 문제를 안고있어 안드로이드 코드를 통해 hdfs 클러스터에 연결을 시도했다. 아래 로그 파일과 코드가 포함되었습니다. 연결이 제대로 설정되었지만 연결 용 소켓을 만드는 데 문제가 있습니다.socketError : Permission Denied
Connect_Ssh:
DllDate: Aug 30 2017
ChilkatVersion: 9.5.0.69
UnlockPrefix: Anything for 30-day trial
Architecture: Little Endian; 32-bit
Language: Android Java
VerboseLogging: 0
connectInner:
hostname: 202.53.13.23
port: 1032
sshConnect:
connectSocket:
connect_ipv6_or_ipv4:
ai_family: 2
ai_socktype: 1
ai_protocol: 6
socketErrno: 13
socketError: Permission denied
Failed to create socket for connecting.
--connect_ipv6_or_ipv4
--connectSocket
Failed to establish initial TCP/IP connection
hostname: 202.53.13.23
port: 1032
--sshConnect
--connectInner
Failed.
--Connect_Ssh
--ChilkatLog
다음은 위의 로그 파일이 인쇄되는 코드입니다. 코드 :
package com.example.sunny.clusteraccess;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import com.chilkatsoft.CkSsh;
public class MainActivity extends AppCompatActivity {
private static final String TAG = "Chilkat";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
CkSsh ssh = new CkSsh();
// Any string automatically begins a fully-functional 30-day trial.
boolean success = ssh.UnlockComponent("Anything for 30-day trial");
if (success != true) {
Log.i(TAG, ssh.lastErrorText());
return;
}
String hostname;
int port;
// Hostname may be an IP address or hostname:
hostname = "202.53.13.23";
port = 22;
success = ssh.Connect(hostname,port);
if (success != true) {
Log.i(TAG, ssh.lastErrorText());
return;
}
success = ssh.AuthenticatePw("student","kmit");
if (success != true) {
Log.i(TAG, ssh.lastErrorText());
return;
}
Log.e(""+success,"");
int channelNum;
channelNum = ssh.OpenSessionChannel();
if (channelNum < 0) {
Log.i(TAG, ssh.lastErrorText());
return;
}
success = ssh.SendReqExec(channelNum,"hdfs dfs -ls");
if (success != true) {
Log.i(TAG, ssh.lastErrorText());
return;
}
success = ssh.ChannelReceiveToClose(channelNum);
if (success != true) {
Log.i(TAG, ssh.lastErrorText());
return;
}
String cmdOutput = ssh.getReceivedText(channelNum,"ansi");
if (ssh.get_LastMethodSuccess() != true) {
Log.i(TAG, ssh.lastErrorText());
return;
}
Log.e(TAG, cmdOutput);
ssh.Disconnect();
}
static {
System.loadLibrary("chilkat");
}
}