Cでソケットプログラミングを実装しようとしています。クライアントがサーバー(Ubuntu)に接続しようとすると、「接続に失敗しました」などのエラーが表示されます。
だから問題はポートにあると思います。ソケットプログラミングには5454/tcpポートを使用します。
ポート5454がリッスンしているかどうかはどうすればわかりますか?それ以外の場合、UbuntuのCでTCPソケットプログラミングに使用できるポートは何ですか?これは単にポートの問題ですか、それとも私のコードに問題がありますか?それとも、LINUX Ubuntuに必要な設定はありますか?
編集する: コードセグメント:
int socket_send;
struct sockaddr_in address;
printf("\n Initialization Socket....");
socket_send = socket(AF_INET,SOCK_STREAM,0);
if(socket_send == -1)
{
perror("\n Socket not created.Error:");
return 1;
}
printf("\n Socket created");
address.sin_family=AF_INET;
address.sin_addr.s_addr=inet_addr(ip);
address.sin_port=htons(5454);
if(connect(socket_send,(struct sockaddr*)&address,sizeof(struct sockaddr))<0)
{
perror("\nConnetion failed.Error:");
return 1;
}
printf("\n Connected");
if(send(socket_send,(char*)buffer,size,flag)<0)
{
perror("\nSending failed.Error:");
return 1;
}
printf("\n Data successfully sent");
close(socket_send);
編集する:ポートに問題があって、先ほどUbuntuを再インストールしたら動作になりました。みんなありがとうございます。
答え1
CIでプログラミングしていて、ポートが開いているかどうかを示す小さなフラグメントを公開したいので、文字列を出力するようにプログラムしました。ニーズに合わせて簡単に変更できます。
2番目の質問に答えるには、ここにいる誰もが言ったように、システムのスーパーユーザー(root)であり、他のアプリケーションでそのポートを使用していない場合は、ほぼすべてのポートを使用できます。ルートでない場合は、1024以上のポートを開くことができます。
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
int main(int argc, char *argv[])
{
int portno = 5454;
char *hostname = "192.168.56.101";
int sockfd;
struct sockaddr_in serv_addr;
struct hostent *server;
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0) {
error("ERROR opening socket");
}
server = gethostbyname(hostname);
if (server == NULL) {
fprintf(stderr,"ERROR, no such host\n");
exit(0);
}
bzero((char *) &serv_addr, sizeof(serv_addr));
serv_addr.sin_family = AF_INET;
bcopy((char *)server->h_addr,
(char *)&serv_addr.sin_addr.s_addr,
server->h_length);
serv_addr.sin_port = htons(portno);
if (connect(sockfd,(struct sockaddr *) &serv_addr,sizeof(serv_addr)) < 0) {
printf("Port is closed");
} else {
printf("Port is active");
}
close(sockfd);
return 0;
}
答え2
いくつかの方法がありますが、最も一般的な方法は次のとおりです。
# netstat -ltun
もちろん、grep
他の(正規)式を使用することもできます。
別のコンピュータ(クライアントとサーバー)を使用している場合iptables
でも、これを確認することをお勧めします。
現在プログラムで使用されていないほぼすべてのポートを使用できます。ただし、/etc/services
既知のポートと予約済みのポートを確認してください。
答え3
リンクを確認してください(http://wi-fizzle.com/article/458)TCPポートが開いていますか?
nc -z <host_or_ip> <port> 1>/dev/null 2>&1; result=$?;
if [ $result -eq 0 ]; then
echo 'the port is open for tcp connections'
else
echo 'the port was closed'
fi
答え4
プロセスがTCPポートにバインドされていることを確認するための最良のツールですnetstat
。このように実行すると、バインドされたプロセス(存在する場合)の名前のリストとポートへの接続とその状態を取得できます。
はい
$ netstat -tapn | head -15
(Not all processes could be identified, non-owned process info
will not be shown, you would have to be root to see it all.)
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:49006 0.0.0.0:* LISTEN -
tcp 0 0 0.0.0.0:111 0.0.0.0:* LISTEN -
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN -
tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN -
tcp 0 0 0.0.0.0:17500 0.0.0.0:* LISTEN 3516/dropbox
tcp 0 0 0.0.0.0:17501 0.0.0.0:* LISTEN 3517/dropbox
tcp 0 0 0.0.0.0:2143 0.0.0.0:* LISTEN 4383/ssh
tcp 0 0 127.0.0.1:1986 0.0.0.0:* LISTEN 2757/mono
tcp 0 0 0.0.0.0:2025 0.0.0.0:* LISTEN 4383/ssh
tcp 0 0 192.168.1.20:58285 198.252.206.25:80 TIME_WAIT -
tcp 0 0 192.168.1.20:58188 198.252.206.25:80 ESTABLISHED 3830/chrome --purge
tcp 0 0 192.168.1.20:58286 198.252.206.25:80 TIME_WAIT -
tcp 0 0 192.168.1.20:54000 174.37.23.130:6667 ESTABLISHED 2696/pidgin
上記の3番目の列には、ローカルに開いているポートと接続を許可するリモートポートが表示されます(たとえば、次の2行)。
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN -
tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN -
これら2行は、ポート22(sshd)でリッスンしており、私たちが持っているすべてのインターフェイス(ネットワークカード、イーサネット、ワイヤレスなど)からの接続を受け入れることを喜んで示しています。現在、このポートへの接続はありません。
2行目は、ポート631でCUPSサーバー(印刷用)を実行しており、localhost(127.0.0.1)インターフェースを介してのみ接続できることを示しています。
下に下がると、次の2行があります。
tcp 0 0 192.168.1.20:58285 198.252.206.25:80 TIME_WAIT -
tcp 0 0 192.168.1.20:58188 198.252.206.25:80 ESTABLISHED 3830/chrome --purge
これは、IPアドレスが198.252.206.25のWebサイトにアクセスしていることを示します。私たちはポート80(HTTP)を介してサーバーにアクセスするので、これがウェブサイトであることを知っています。また、IPアドレスを検索すると、次のものが見つかります。
$ dig -x 198.252.206.25 +short
stackoverflow.com.