如何解决zookeeper client端与server端连接不上的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何解决zookeeper client端与server端连接不上的问题相关的知识,希望对你有一定的参考价值。

  方法一
  1、鼠标右键点击“计算机”,选择“设备管理器”;
  2、找到"网络适配器“并点击它;
  3、对网卡进行更新,然后看是否能连接上网络。
  方法二
  1、在电脑桌面的最右下端找到红圈标记的图标;
  2、点击"打开网络和共享中心”;
  3、点击“更改适配器”;
  4、尝试设置其他的联网方式连接网络。
  方法三
  1、下载一个360卫士加速球;
  2、点击“网速”,再点击“断网急救箱”;
  3、在弹出的页面中选择“全面诊断”。
参考技术A 问问题和回答问题的是一个人吧 真的智障。

应用java多线程实现server端与多client之间的通信

应用多线程来实现server与多线程之间的通信的基本步骤

1、server端创建ServerSocket,循环调用accept()等待client链接

2、client创建一个Socket并请求和server端链接

3、server端接受client请求,创建socekt与该client建立专线链接

4、建立链接的socket在一个单独的线程上对话

5、server继续等待新的链接

server端Server.java
package test.concurrent.socket;

import java.io.*;
import java.net.InetAddress;
import java.net.ServerSocket;
import java.net.Socket;

/**
 * Created by dong on 15-6-22.
 * 基于TCP协议的Socket通信。实现用户登录
 * 服务器端
 */
public class Server {

    public static void main(String[] args) {

        try {
            //1、创建一个服务器端Socket,即ServerSocket, 指定绑定的端口,并监听此端口
            ServerSocket serverSocket = new ServerSocket(8888);
            Socket socket = null;
            //记录client的数量
            int count = 0;
            System.out.println("***服务器即将启动,等待client的链接***");
            //循环监听等待client的链接
            while (true){
                //调用accept()方法開始监听,等待client的链接
                socket = serverSocket.accept();
                //创建一个新的线程
                ServerThread serverThread = new ServerThread(socket);
                //启动线程
                serverThread.start();

                count++; //统计client的数量
                System.out.println("client的数量: " + count);
                InetAddress address = socket.getInetAddress();
                System.out.println("当前client的IP : " + address.getHostAddress());
            }

        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
服务器端线程处理类ServerThread.java
package test.concurrent.socket;

import java.io.*;
import java.net.Socket;

/**
 * Created by dong on 15-6-22.
 * server端线程处理类
 */
public class ServerThread extends Thread {

    //和本线程相关的Socket
    Socket socket = null;
    public ServerThread(Socket socket){
        this.socket = socket;
    }

    //线程运行的操作,响应client的请求
    public void run(){

        InputStream is = null;
        InputStreamReader isr = null;
        BufferedReader br = null;

        OutputStream os = null;
        PrintWriter pw = null;
        try {

            //获取一个输入流,并读取client的信息
            is = socket.getInputStream();
            isr = new InputStreamReader(is); //将字节流转化为字符流
            br = new BufferedReader(isr); //加入缓冲
            String info = null;
            //循环读取数据
            while ((info = br.readLine()) != null){
                System.out.println("我是server。client说: " +info);
            }

            socket.shutdownInput(); //关闭输入流

            //获取输出流。响应client的请求
            os = socket.getOutputStream();
            pw = new PrintWriter(os); //包装为打印流
            pw.write("欢迎你");
            pw.flush();  //将缓存输出


        } catch (IOException e) {
            e.printStackTrace();
        }finally {


                try {
                    //关闭资源
                    if (pw != null)
                        pw.close();
                    if (os != null)
                        os.close();
                    if (is != null)
                        is.close();
                    if (isr != null)
                        isr.close();
                    if (br != null)
                        br.close();
                    if (socket != null)
                        socket.close();
                } catch (IOException e) {
                    e.printStackTrace();

                }

        }



    }
}
clientClient.java
package test.concurrent.socket;

import java.io.*;
import java.net.Socket;

/**
 * Created by dong on 15-6-22.
 * client
 */
public class Client {

    public static void main(String[] args) {

        try {
            //1、创建clientSocket,指定server端口号和地址
            Socket socket = new Socket("localhost",8888);
            //2、获取输出流,向server发送信息
            OutputStream os = socket.getOutputStream(); //字节输出流
            PrintWriter pw  = new PrintWriter(os); //将输出流包装为打印流
            pw.write("username:tom; password:456");
            pw.flush();
            socket.shutdownOutput(); //关闭输出流

            InputStream is = socket.getInputStream();
            InputStreamReader isr = new InputStreamReader(is);
            BufferedReader br = new BufferedReader(isr);

            String info = null;
            //循环读取
            while ((info = br.readLine()) != null){
                System.out.println("我是client:server说:" + info);
            }

            br.close();
            is.close();
            isr.close();


            pw.close();
            os.close();
            socket.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}




以上是关于如何解决zookeeper client端与server端连接不上的问题的主要内容,如果未能解决你的问题,请参考以下文章

应用java多线程实现server端与多client之间的通信

Docker 安全问题(Client 端与 Daemon 的通信安全)

Docker 安全问题(Client 端与 Daemon 的通信安全)

使用gRPC搭建Server端与Client端

zookeeper集群之间如何通讯

解决ZooKeeper集群节点状态报错Client address: localhost. Error contacting service. It is probably not running