在IIS上部署Go?API項(xiàng)目
問(wèn)題場(chǎng)景
我這邊原先的技術(shù)棧主要是 .NET(Core), 所以服務(wù)器基本上都是 Windows Server + IIS.
這次有個(gè) API 服務(wù)用 Go 重寫, 但是部署有點(diǎn)不美, 直接執(zhí)行黑框框不好看, 也容易丟, 做成服務(wù)又不方便更新維護(hù), 想著能不能繼續(xù)掛載在 IIS 下.
于是乎...
首先想到的是 IIS 下有個(gè) FastCGI 支持, 以前還在 IIS 下部署過(guò) PHP 項(xiàng)目.
搜到 Go 中有個(gè) net/http/fcgi 庫(kù), 寫個(gè)簡(jiǎn)單服務(wù)驗(yàn)證一下, 代碼如下:
package main
import (
"net"
"net/http"
"net/http/fcgi"
)
func handler(resp http.ResponseWriter, req *http.Request) {
resp.Write([]byte("hello"))
}
func main() {
mux := http.NewServeMux()
mux.HandleFunc("/", handler)
l, err := net.Listen("tcp", ":0")
if err != nil{
panic(err)
}
err = fcgi.Serve(l, mux)
if err != nil{
panic(err)
}
}執(zhí)行 go run main.go 命令后, 程序沒(méi)有任何異常或輸出直接就結(jié)束了...
資料搜了一圈看到這玩意基本已被遺忘在不知道哪個(gè)旮旯里了...
然后搜到 Azure 前些年用 HttpPlatformHandler Module 在 IIS 上支持 Java/Node/... 應(yīng)用程序.
試了下基本也是廢了.
解決方案
最后溜達(dá)了一圈, 發(fā)現(xiàn) HttpPlatformHandler 已被 ASPNETCore Module 宿主模塊取代.
那么就跟我們?cè)?IIS 上部署 ASP.NET Core 應(yīng)用程序一樣, 首先下載并安裝 ASP.NET Core Hosting Bundle, 了解更多可參閱 ASP.NET Core Module
然后新建對(duì)應(yīng)的站點(diǎn), 應(yīng)用程序池調(diào)整成 無(wú)托管代碼

IIS 這邊已經(jīng)準(zhǔn)備就緒.
來(lái)看看我們代碼和配置
// main.go
package main
import (
"fmt"
"net"
"net/http"
"os"
)
func handler(w http.ResponseWriter, r *http.Request) {
w.Write([]byte("Go running on IIS"))
}
func main() {
mux := http.NewServeMux()
mux.HandleFunc("/", handler)
// 獲取由 ACNM 設(shè)置的環(huán)境變量
port := "0" // default
envPort := os.Getenv("ASPNETCORE_PORT")
if envPort != "" {
port = envPort
fmt.Println("get env ASPNETCORE_PORT", port)
}
l, err := net.Listen("tcp", ":" + port)
if err != nil{
panic(err)
}
defer l.Close()
fmt.Println("listening on", l.Addr().String())
err = http.Serve(l, mux)
if err != nil{
panic(err)
}
}關(guān)鍵點(diǎn)就是代碼中要通過(guò)獲取 ACNM 提供的端口環(huán)境變量, 也就是 ASPNETCORE_PORT, 熟悉 ASP.NET Core 的小伙伴對(duì)這個(gè)應(yīng)該不陌生了.
然后構(gòu)建我們的可執(zhí)行文件 xxx.exe
go build
然后配置 web.config 內(nèi)容如下:
<!-- web.config -->
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<location path="." inheritInChildApplications="false">
<system.webServer>
<handlers>
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath=".\your.exe" arguments="" stdoutLogEnabled="true" stdoutLogFile=".\stdout" />
</system.webServer>
</location>
</configuration>把 xxx.exe 和 web.config 扔到前面新建的站點(diǎn)中即可.
后續(xù)更新升級(jí)直接替換 exe 即可.
Go 寫的程序體積比較小, 構(gòu)建后也只有單個(gè)執(zhí)行文件, 清爽多了.

最后來(lái)個(gè)效果圖

注意事項(xiàng)
如出現(xiàn)以下錯(cuò)誤信息, 可能是端口號(hào)已被占用, 換個(gè)端口號(hào)試試
[ERROR] listen tcp :8080: bind: An attempt was made to access a socket in a way forbidden by its access permissions.
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
WIN7/win2008 r2 X64系統(tǒng)IIS 7.5 ACCESS數(shù)據(jù)庫(kù)連接故障解決方法
這篇文章主要介紹了WIN7 X64系統(tǒng)IIS 7.5 ACCESS數(shù)據(jù)庫(kù)連接故障解決方法,需要的朋友可以參考下2015-01-01
windows 2012 r2 用戶策略無(wú)法下發(fā)腳本
本文給大家分享的是在windows server 2012 r2系統(tǒng)中出現(xiàn)用戶策略無(wú)法下發(fā)腳本的問(wèn)題的解決方法,非常的實(shí)用,有需要的小伙伴可以參考下2018-04-04
IIS6 安裝與配置.net 2.0過(guò)程的詳細(xì)圖解
本次試用的是IIS6.0版本在Windows Service 2003上的安裝過(guò)程2010-03-03
Windows 2008 R2服務(wù)管理器刷新失敗的解決方法
刷新服務(wù)器管理器時(shí)出現(xiàn)意外錯(cuò)誤: 異常來(lái)自 HRESULT:0x800F0818,有關(guān)詳細(xì)信息,請(qǐng)參閱事件日志: 診斷、事件查看器、應(yīng)用程序和服務(wù)日志、Microsoft、Windows、服務(wù)器管理器、操作2016-08-08
IIS W3C日志記錄字段和HTTP狀態(tài)代碼的說(shuō)明
一般情況下很多朋友都不在意IIS日志,有的是因?yàn)橘?gòu)買的虛擬主機(jī)不給提供,有的是提供了,但是還必須與服務(wù)器管理員聯(lián)系才能得到。2010-07-07
詳解IIS中的重寫工具下關(guān)于操作重定向URL中的{R:N}與{C:N}使用介紹
這篇文章主要介紹了詳解IIS中的重寫工具下關(guān)于操作重定向URL中的{R:N}與{C:N},需要的朋友可以參考下2017-03-03
Windows10中的IIS10安裝php manager的方法
這篇文章主要介紹了Windows10中的IIS10安裝php manager的方法,需要的朋友可以參考下2016-09-09

