使用socket client源码,调用addresstool地址关联算法

之前使用httpserver方式发布地址关联服务,发现每秒只能处理1800条地址,远远没有达到本地计算每秒1万条的速度,于是改变思路,使用socket发布服务。
这是客户端代码
直接上代码

package org.socket;

import org.address.AddressTool;
import org.address.entity.StandardAddress;

import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;
import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets;

public class AddressSocket {

    AddressTool ss = new AddressTool();

    public AddressSocket() throws Exception {
        ss.loadFromJson("D:\\","address4.json");
    }
    /**
     * 服务端程序
     */
    public void server() throws IOException {

        // 服务端监听 9528 端口
        ServerSocket serverSocket = new ServerSocket(9966);
        System.out.println("等待连接");
        Socket client = serverSocket.accept();
        System.out.println("连接成功!");
        while (true) {
            try {
                // 获取客户端输入流
                InputStream inputStream = client.getInputStream();
                byte[] bytes = new byte[1024];
                int read = inputStream.read(bytes);

                String addr = new String(bytes, 0, read, Charset.defaultCharset());
                // 客户端发来的消息
//                System.out.println("客户端:" + addr);
                StandardAddress address = ss.getStdAddress(addr);
                // 给客户端发端东西
                client.getOutputStream().write(address.toString().getBytes(StandardCharsets.UTF_8));
            }catch (Exception e){
//                System.out.println("无客户端链接!!!");
                client.close();
                client = serverSocket.accept();
            }


        }
    }


    class Task implements Runnable {

        private ServerSocket serverSocket;

        /**
         * 构造函数
         */
        public Task(ServerSocket socket) {
            this.serverSocket = socket;
        }

        @Override
        public void run() {
            try {
                handlerSocket();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }

    }

    private String handlerSocket(){
        return "";
    }
    public static void main(String[] args) throws Exception {
        AddressSocket tcpSocketServer = new AddressSocket();
        tcpSocketServer.server();;
    }
}

结合上一篇socketserver案例,可以发布一个完整的服务了

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Mina 是一个轻量级的网络应用框架,它提供了一种高效、可扩展、可靠的方式来处理网络通信。下面是使用 Mina 建立 Socket Client 的示例代码: ```java import java.net.InetSocketAddress; import java.nio.charset.Charset; import org.apache.mina.core.future.ConnectFuture; import org.apache.mina.core.service.IoConnector; import org.apache.mina.core.session.IoSession; import org.apache.mina.filter.codec.ProtocolCodecFilter; import org.apache.mina.filter.codec.textline.TextLineCodecFactory; import org.apache.mina.transport.socket.nio.NioSocketConnector; public class MinaSocketClient { private static final String HOSTNAME = "localhost"; private static final int PORT = 9123; public static void main(String[] args) { IoConnector connector = new NioSocketConnector(); connector.getFilterChain().addLast("codec", new ProtocolCodecFilter(new TextLineCodecFactory(Charset.forName("UTF-8")))); connector.setHandler(new MinaClientHandler()); ConnectFuture future = connector.connect(new InetSocketAddress(HOSTNAME, PORT)); future.awaitUninterruptibly(); IoSession session = future.getSession(); session.write("Hello, Mina!"); session.getCloseFuture().awaitUninterruptibly(); connector.dispose(); } } ``` 在上面的代码中,我们首先创建了一个 `IoConnector` 对象,它是 Mina 中负责处理连接的对象。接着,我们设置了一个 `ProtocolCodecFilter`,它用于将字节流转换成文本行的格式。然后,我们创建了一个 `MinaClientHandler` 对象,它用于处理接收到的消息。接着,我们调用 `connector.connect()` 方法连接到服务器,并等待连接完成。如果连接成功,我们会得到一个 `IoSession` 对象,我们可以通过它来发送消息。最后,我们等待 `IoSession` 关闭,并释放资。 需要注意的是,这只是一个简单的示例代码,实际使用中还需要处理连接失败等异常情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

addresstool

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值