golang 创建unix socket http服务端

服务端

go 复制代码
package main

import (
	"fmt"
	"net"
	"net/http"
	"os"
)

func main() {

	http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
		w.Write([]byte("hello"))
	})

	http.HandleFunc("/world", func(w http.ResponseWriter, r *http.Request) {
		w.Write([]byte("world"))
	})
	
	// unix socket地址
	addr := "test.sock"
	
	// 如果文件先存在,必须先移除
	if err := os.Remove(addr); err != nil && err == os.ErrNotExist {
		panic(err)
	}
	
	// 使用uinx网络协议
	l, err := net.Listen("unix", addr)
	if err != nil {
		fmt.Println("net.ListenUnix", err)
		return
	}

	err = http.Serve(l, nil)
	if err != nil {
		fmt.Println("http.Serve", err)
		return
	}
}

客户端调用

go 复制代码
package main

import (
	"context"
	"fmt"
	"io"
	"net"
	"net/http"
)

func main() {

	addr1 := "test.sock"

	// 创建一个基于 Unix 域套接字的 HTTP 客户端
	transport := &http.Transport{
		DialContext: func(ctx context.Context, network string, addr string) (net.Conn, error) {
			return net.Dial("unix", addr1)
		},
	}

	client := &http.Client{Transport: transport}

	// 创建一个 HTTP GET 请求
	// http://unix/world中的unix可以为任何值,建议使用有意义的域名,例如本地服务localhost
	req, err := http.NewRequest("GET", "http://unix/world", nil)
	if err != nil {
		fmt.Println("Error creating request:", err)
		return
	}

	// 发送请求并获取响应
	resp, err := client.Do(req)
	if err != nil {
		fmt.Println("Error sending request:", err)
		return
	}
	defer resp.Body.Close()

	// 读取响应内容
	body, err := io.ReadAll(resp.Body)
	if err != nil {
		fmt.Println("Error reading response:", err)
		return
	}

	// 打印响应内容
	fmt.Println("Response from server:", string(body))
}
相关推荐
Tony Bai7 小时前
Go 安全新提案:runtime/secret 能否终结密钥残留的噩梦?
java·开发语言·jvm·安全·golang
普普通通的南瓜12 小时前
一年期免费IP证书,为公网IP地址提供HTTPS加密
网络·网络协议·tcp/ip·安全·http·金融·https
卿雪14 小时前
Redis 线程模型:Redis为什么这么快?Redis为什么引入多线程?
java·数据库·redis·sql·mysql·缓存·golang
青果全球http16 小时前
HTTP代理原理揭秘:如何实现高效数据中转?
网络·网络协议·http
im_AMBER16 小时前
weather-app开发手记 01 HTTP请求基础 | Axios GET 请求
笔记·网络协议·学习·计算机网络·http·axios
源代码•宸17 小时前
分布式缓存-GO(项目整体架构简介、Ubuntu 22.04 64位安装GoLang、安装Docker、解决Go module 的依赖问题)
经验分享·分布式·后端·ubuntu·缓存·docker·golang
MC皮蛋侠客17 小时前
Linux安装go及环境配置教程
linux·运维·golang
golang学习记17 小时前
Redis Pipeline 实战指南:提升 Go 后端性能的利器
redis·golang·php
kgduu19 小时前
go ethreum之Trie
开发语言·后端·golang
打不了嗝 ᥬ᭄20 小时前
【Linux】多路转接 Select , Poll和Epoll
linux·网络·c++·网络协议·http