Docker中运行golang编写Web连接数据库程序

1、通过 https://download.docker.com/linux/fedora/28/x86_64/stable/Packages/ 下载自动安装docker最新版本的containerd.io、docker-ce-cli、docker-ce(注意顺序)如下图:

image.png

2、连接postgres数据库的服务端代码:

package main

import (
    "database/sql"
    "fmt"
    "html/template"
    "log"
    "net/http"

    _ "github.com/lib/pq"
)

type authUser struct {
    UserLoginName string
    UserName      string
}

//IndexHandler 首页展示用户信息
func IndexHandler(w http.ResponseWriter, r *http.Request) {
    if r.Method == "GET" {
        dbUser := "postgres"
        dbPass := "mypassword"
        dbHost := "localhost"
        dbPort := "5432"
        dbName := "<database_name>"
        connStr := fmt.Sprintf("host=%s port=%s user=%s password=%s dbname=%s sslmode=disable", dbHost, dbPort, dbUser, dbPass, dbName)
        db, err := sql.Open("postgres", connStr)
        if err != nil {
            log.Fatal(err)
        }
        rows, err := db.Query("SELECT USER_LOGIN_NAME,USER_NAME FROM public.AUTH_USER")
        if err != nil {
            log.Println(err)
        }
        var authUsers []authUser
        for rows.Next() {
            var au authUser
            rows.Scan(&au.UserLoginName, &au.UserName)
            authUsers = append(authUsers, au)
        }
        t, err := template.ParseFiles("templates/index.html")
        if err != nil {
            log.Println(err)
        }
        err = t.Execute(w, authUsers)
        if err != nil {
            log.Println(err)
        }
    }
}

func main() {
    http.HandleFunc("/", IndexHandler)
    fmt.Println("服务端口:8000")                 //控制台输出信息
    err := http.ListenAndServe(":8000", nil) //设置监听的端口
    if err != nil {
        log.Fatal("ListenAndServe: ", err)
    }
}

3、go语言渲染前端模板代码

<div>
    {{.}}
</div>

4、把应用放入docker中
1)下载pg的alpine镜像:

sudo docker pull postgres:alpine

2)docker-compose.yml内容

services:

  db:
     restart: always
     image: postgres:alpine
     volumes:
             - /home/fedora/data:/var/lib/postgresql/data
     ports:
             - target: 5432
               published: 5432

  webserver:
     image: "webserver"
     volumes:
             - /home/fedora/datafile:/app/datadir
     ports:
             - target: 8000
               published: 8080
     depends_on:
             - db
     links:
             - db:database

3) pg数据库从本地库导出:
在fedora的docker中里执行pg命令行

sudo docker exec -it <container_name> psql -U postgres
create database <database_name>;  #创建数据库
\connect <database_name> #连接数据库
DROP SCHEMA public CASCADE; #删除public SCHEMA

pg导出及导入命令(注意:导入导出文件路径为dockcer映射路径):

#导出
docker <container_name> pg_dump.exe --format=c -n "<dataschema1>" -n "<dataschema2>"  --verbose --host=localhost --port=5432 --username=postgres /<路径>/<数据库名称>
#导入
docker <container_name> pg_restore --verbose  --username=postgres --format=c --dbname=<数据库名称> -1 /<路径>/<备份文件名>.backup

4)生成docker应用程序

sudo docker build -t webserver -f Dockerfile .

5)启动docker应用

sudo docker-compose up

5、docker镜像导入导出

  1. 启动docker
systemctl start docker
  1. 查看镜像
sudo docker images
image.png
  1. 导出webserver和postgres数据库镜像
sudo docker save -o webserver_img.tar webserver
sudo docker save -o postgres_img.tar postgres

4)加载镜像

docker load -i webserver_img.tar
docker load -i postgres_img.tar

6、使用中的一些其他问题
1)有时go语言升级后产生与alpine linux不兼容的问题导致以下错误

docker standard_init_linux.go:207: exec user process caused "no such file or directory"

解决方案为把alpine linux依赖镜像替换为ubuntu
2)go语言连接数据库地址为实际发布地址,ubuntu依赖镜像会使127.0.0.1会指向容器内部
3)如果容器里有域名访问还需要给docker应用加dns解析

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,084评论 1 32
  • 买了本画画书初学画画,请老师指点。突然发现这个APP,以后就跟着APP学了~(色铅笔画)
    倔强的小学生阅读 262评论 1 0
  • 做自己情绪的主人,多一些自己的时间。
    长桥灯上闹阅读 110评论 0 0
  • 《想家》 静静的徘徊, 在夜里无限延长, 整树的星星, 长出翅膀飞满天空, 直到家里的灯光点亮, 我一直期盼的圆月...
    蓝心诚阅读 119评论 0 3
  • 九点开始动笔画画,一直到十二点,挤牙膏般地画出了一张画,这是第一次吧,画画的第四年,憋屈,好像突然间手就废了,脑子...
    Eyfgff阅读 239评论 2 1