Go関連のことを調べてみた2022年03月09日

Go関連のことを調べてみた2022年03月09日
目次

【対処法】unable to open tcp connection with host ‘localhost:1433’: dial tcp [::1]:1433: connectex: No connection could be made because the target machine actively refused it.

社内ツールの開発を試みてGoでSQLserverを扱っている公式チュートリアルを進めていたところ、タイトルのエラーに遭遇して少し苦戦しました。その対処法を記事にします。
[https://www.microsoft.com/en-us/sql-server/developer-get-started/go/windows/step/2.html](https://www.microsoft.com/en-us/sql-server/developer-get-started/go/windows/step/2.html)

## TCPIPを無効から有効に切り替える

![sqlserver.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/951392/70c34883-1186-6d85-e65a-9d9d29098bee.png)

以下に対処法が書いてありましたが英語なので見逃してしまう方がいるかもと思い記事にしました。
[https://community.grafana.com/t/not-ab

元記事を表示

GoのCLIでテキスト入力をVimとかでやりたかった件

# はじめに
CLIのTwitterクライアントとか作りたいなー って思った
なので、複数行のTweetをコマンドラインで入力するんだったら、Vimとか使いたいなーって思った

## ググった
[GoでVimを開いて編集内容をパースする方法](https://qiita.com/lighttiger2505/items/d3b9ee9884c75a7819d8)
最高やん!

## 結果
[kotaoue/go-eeditor](https://github.com/kotaoue/go-eeditor)を用意した

“`Go
import (
“fmt”

“github.com/kotaoue/go-eeditor”
)

func main() {
editor := eeditor.NewEditor()
b, _ := editor.Open()
fmt.Println(string(b))
}
“`
みたいなコードで、Vimでテキスト編集した結果をbyteで受け取れる

起動時のパラメータ変更すれば、Emacsも使える
“`
editor := eedito

元記事を表示

【Golang】”net” モジュールを使った静的リンクバイナリを Docker + scratch で使う際のビルドの注意【”net/http” “net/url” など】

> Go 言語(以下 Golang)v1.16 以降で、”`net`” モジュールを使ったバイナリを Docker のマルチステージ・ビルドでコンパイルし、`scratch` イメージで使いたい。

例えば “`net/http`” や “`net/url`” パッケージなどを使って `HTTP GET` リクエストするものなど。しかし、静的リンクしないと `standard_init_linux.go:228: exec user process caused: no such file or directory` エラーが発生するし、静的リンクさせてもデータが取得できない。

**Go v1.16 + Docker v20.10 以降で動く情報**が欲しかったのですが、色々ググっても Go v1.**4** 時代の古い情報や、古い Golang と Docker のバージョンの組み合わせ情報しかありませんでした。あっても新旧混在の組み合わせだったりと、なかなか動かなかったので未来の自分のググラビリティとして。

## TL; DR (今北産業

元記事を表示

[Go][AtCoder] bufio.NewScannerの標準入力でハマったこと 最大サイズ

## 概要

最近Golangを書くことが多くなりました。普段はWeb開発ばかりやってますがそれ以外にも前から競プロに興味がありました。
なのでせっかくなのでGolangで始めてみようかなと思い立った矢先、いきなり問題にハマったのです。

ただ学びにもなったので備忘録としてこの記事を書いています。

## ハマってしまった問題

僕がハマってしまった問題は下記です。

問題としては入力文字列を昇順にソートして出力するだけのものでシンプルなものです。

https://atcoder.jp/contests/abc242/tasks/abc242_b

僕の提出回答は下記でした。

一見ACになりそうなのですが、結果としてはWAでした。

やっていることとしては間違っておらずでして、

受け取った文字列からstring型のsliceを作成して1語ずつ格納します。

その後, `sort.Strings([]string)`を使ってsliceを昇順にソートします。

最後は`strings.Join`を用いて文字列を作成して出力で完了です。

でも何が原因でWAになってしまうか分からず、

元記事を表示

AWS App RunnerでGolangのサーバーをサクッと立ててみる

# AWS App Runnerとは?
コンテナ化されたWebアプリを簡単にデプロイすることができるサービスです。(裏側ではFargateが使われているらしい)
2021年の5月に登場したサービスなので比較的新しいサービスっぽいです。

コンテナを動作させる手段としてはAmazon ECSがありますが、それよりもサクッとサーバーを立てたい時に重宝しそうです。

# 料金体系(@東京リージョン)
以下の3つの要素から構成されます。
1. プロビジョニングされるメモリ ・・・ 0.009USD/GB
2. アクティブなコンテナインスタンスのCPUとメモリ・・・0.081 USD/vCPU + 0.009USD/GB
3. ビルド料金・・・0.005 USD/ビルド時間 (分)

1vCPU・メモリ2GB・ビルドなしで1ヶ月アクティブに運用すると、**約70ドル**のコストがかかります。

# 2022年2月のアップデートでVPCのトラフィックがサポートに
リリースノートによるとApp RunnerがVPCのリソースにアクセス可能となったそうです。
https://docs.aws.amaz

元記事を表示

【Golang】gqlgen、gin、GORMを使ったプロジェクトテンプレート

# はじめに

Goの学習のためgin、gqlgen、GORMを使ってGraphQLのAPIを作成しました。
備忘のためにプロジェクトのテンプレートとその説明を残します。

作成したテンプレートは以下に公開しています。

https://github.com/Ruketa/go-gqlgen-gin-template

# 環境
– Golang バージョン 1.17
– 使用ライブラリ、FW
– Gin : Web Framework : https://github.com/gin-gonic/gin
– Gorm : ORM library : https://github.com/go-gorm/gorm
– Gorm PostgreSQL Driver : https://github.com/go-gorm/postgres
– INI : INI file package : https://pkg.go.dev/gopkg.in/ini.v1
– gqlgen : GraphQL library : https://github

元記事を表示

GolangのValidationチェック(go-playground編)

#初めに
GolangでのValidationチェックを実施する記事です。

#サンプルコード
“`go:main.go
package main

import (
“fmt”

“github.com/go-playground/validator/v10”
)

// User contains user information
type User struct {
FirstName string `validate:”required”`
LastName string `validate:”required”`
Age uint8 `validate:”gte=0,lte=130″`
Email string `validate:”required,email”`
FavouriteColor string `validate:”iscolor”` // alias for ‘hexcolor|rgb|rgba|hsl|hsl

元記事を表示

[Golang] ユニットテストにおける正しい後処理の書き方:t.Cleanup()

ユニットテストの**後処理**を行う場合、

`defer`は**並列**で動いている**サブテストの終了を待たずに実行**されてしまう問題がある。

全てのサブテストが終了してから後処理を行たいなら `t.Cleanup()` を使おう。

## **`Defer`による後処理の例**

“`go
package main

import (
“log”
“testing”
)

func TestDefer(t *testing.T) {
tcs := map[string]string{
“A”: “1”,
“B”: “2”,
“C”: “3”,
}

defer log.Printf(“End”)

for tn, tc := range tcs {
tc := tc
t.Run(tn, func(t *testing.T) {
t.Parallel()
log.Println(tc)
})
}
}
“`

そのログの抜粋:

“`bash
2009/11/10 23:00:00 End
2009/11/10 23:00:

元記事を表示

Go言語 + Windows Terminalで、任意の文字にハイパーリンクを埋め込むエスケープシーケンス

# 結論

“`golang
package main
import (
“fmt”
)
func main() {
fmt.Println(“\033]8;;https://www.google.com/\aGoogle\033]8;;\aへリンク”)\\->Googleへリンク
}
“`

# 参考
[ターミナルエミュレータ内でクリッカブルなリンクを作る方法](https://qiita.com/aosho235/items/335fc2f4b002a8251a2f)
[How to add hyperlinks to a terminal [ Node.js ]](https://stackoverflow.com/questions/69314689/how-to-add-hyperlinks-to-a-terminal-node-js)
[Explicit hyperlinks and context information for your terminal](https://www.uninformativ.de/blog/postings/2018-04-14

元記事を表示

Google Compute Engine の startup script で $ go install と インストールされたバイナリを実行する方法

## TL;DR

“`bash
metadata_startup_script = <<-EOF #!/bin/bash TARGET_REPOSITORY_URL=github.com/... # ここは適宜差し替えてください TARGET_BIN_NAME=... # ここも mkdir /home/user export HOME=/home/user cd /usr/local/src wget https://go.dev/dl/go1.17.7.linux-amd64.tar.gz > /dev/null 2>&1
tar -C /usr/local/ -xzf go*.tar.gz > /dev/null 2>&1
GOCACHE=/usr/local/go/cache GOBIN=/usr/local/go/bin GOPATH=/usr/local/go /usr/local/go/bin/go install -v ${TARGET_REPOSITORY_URL}@latest
/us

元記事を表示

Goの静的解析ツールblahbrah

Goの静的解析ツールを作ったので紹介したいと思います。

## 作ったもの
– [blahbrah](https://github.com/granddaifuku/blahbrah)

### 何ができるのか
– タイトルにもある通り、Goの静的解析をしてくれます
– Brace( “{” や “}” )の前後にある空白行を検知することができます

次のコードを例に取ります。
突っ込み所はとてもありますが、一番気になる(?)のは、**レビューで指摘されそうな**、12行目や20行目に存在する空白行ではないでしょうか。
“`main.go
1 package main
2
3 import “fmt”
4
5 type cat struct {
6 name string
7 age int
8 }
9
10 func newCat(name string, age int) cat {
11 return cat{
12
13 name: name,
14 age: age,
15 }
16 }
17
18 func foo(a, b int) int

元記事を表示

0-1ナップサック アルゴリズム

# 何が書いてあるか。
0-1ナップサック問題[^1]のアルゴリズムのGo言語実装サンプル
[^1]: 重量を越えないような物の組み合わせのうち、価値が最大になるようにな組み合わせを求める問題。

“`go
package main
import (
“fmt”
“math”
)
type Kingyo struct {
weight int
kati int
}
func main(){
var N,x int
fmt.Scanf(“%d %d”, &N,&x)

kingyo:=make([]Kingyo,N)
for i:=0;i

元記事を表示

Go の API をフロントサイドから呼び出す

API 側に
“`go
http.Handle(“/”, http.FileServer(http.Dir(“static”)))
“`
“static” フォルダに html などを入れる。

## 詳しく
main.go に
“`go
http.Handle(“/”, http.FileServer(http.Dir(“static”)))
log.Fatal(http.ListenAndServe(“:8080”, nil))
“`
と書いた場合。(main.go があるフォルダ)/static に index.html を入れる。
“`
go run main.go
“`
などで実行すると、localhost:8080/ で index.html が表示される。
localhost:8080/test.html とかで static/test.html が表示される。

“static” フォルダは別フォルダにしても動く。”../test” とかでも問題ない。
“/” を “/top” にして localhost:8080/top にアクセスすると not foun

元記事を表示

Go言語のモジュール実装

モジュールの実装方法と実装したモジュールを利用したmainモジュールを実行するところをできるだけ簡略化して紹介します。

## モジュール用の作成

### モジュール用のディレクトリを生成

“`sh
mkdir greetings
cd greetings
“`

### モジュールの初期化

[go mod init](https://go.dev/ref/mod#go-mod-init)コマンドで現在のディレクトリをルートとする新しいモジュールを初期化(go.modファイルを生成)します。
※go.modファイルはまだ存在していてはなりません。

“`sh
go mod init example.com/greetings
# go: creating new go.mod: module example.com/greetings
“`

### モジュールの実装

“`go
package greetings

import “fmt”

// 大文字から始まる関数はpublic扱いになるので、Hello関数はimportしたモジュールから参照できます。
func

元記事を表示

golang-migrateチュートリアル(migration編)

#初めに
 golang-migrateのチュートリアルです。

#環境
PC:Mac(CPUはintel製)
Go:1.17.6 ←Goのver大事。versionは1.16以降をインストールしてください。
開発エディタ:Visual Studio Code

#ディレクトリ構成
“`shell:ディレクトリ構成
~/go/src/test $ tree
.
├── db
│ └── migrations
│ ├── 000001_create_users_table.down.sql
│ └── 000001_create_users_table.up.sql
├── docker-compose.yml
└── go.mod
2 directories, 4 files
“`

#go-migrateのインストール
“`shell:golang-migrateのインストール
brew install golang-migrate
“`

#事前準備
①DB用意
postgressを用意し、exampleという名のDBを作成する。
②環境依存情報

元記事を表示

Herokuでスクレイピングしようとしてハマったこと

## 初めに
Herokuでスクレイピングしてハマったことをまとめてみました。
記事ではGoとagoutiを使用していますが、Pythonとかにも当てはまると思います。
## invalid session id  エラーが多発
### 下記エラーが発生
“`
failed to retrieve page HTML: request unsuccessful: invalid session id
failed to retrieve page title: request unsuccessful: invalid session id
“`
### 対策
Chromeのオプションに`–disable-gpu`と`–disable-dev-shm-usage`を指定したら解消しました。
“`golang
options := agouti.ChromeOptions(
“args”, []string{
“–headless”,
“–disable-gpu”,
“–disable-dev-shm-usage”,
})
driver := agout

元記事を表示

E2D(End to end – 1)の考察

# はじめに
レイヤードアーキテクチャ、クリーンアーキテクチャ、DIなどのアーキテクチャを使うリポジトリを前提とした話です。

gitOps,CIで単体パッケージだけで完結する単体テストを行う際に依存するモジュールをモックすると思います。
その場合はそのソースコードだけでテストが完結するはずです。

“`golang:example_unit
func TestFoo(t *testing.T) {

mock := gomock.NewBar(ctrl)

target := &Foo{bar: mock}
target.Do()

}
“`

E2Eテストの場合は実際にmain関数相当のものを立ち上げ、Webサーバーなら実際にhttpリクエストを送信してレスポンスの検証等をするために、に依存するDBなど外部ミドルウェアのmockサーバーが起動されlistenするようにクライアントをバインドする構成が多いと思います。

“`golang:example_e2e
func TestE2E(t *testing.T) {
db :=

元記事を表示

Golangによるパスワードの保存

パスワードの保存方法として、

平文のパスワードを単方向ハッシュにかけて保存するのが一般的です。

ハッシュアルゴリズムには`SHA-256`、`SHA-1`、`MD5`等があります。

Golang は `crypto` パッケージで簡単に実装することが可能です。

以下、 `sha256` によるの実装例です。

“`go
//import “crypto/sha256”
h := sha256.New()
io.WriteString(h, “my password”)
fmt.Printf(“% x”, h.Sum(nil))
“`

# より良い方法

大抵の場合は、暗号化時に使用されたハッシュアルゴリズムが上記のような公開されているものであることが原因で、かつ技術の進歩によりパソコンの計算力も上がり、ハッカーが`rainbow table`を使用することで上記の方法でハッシュされたパスワードをクラックすることが(時間的に)難しく無くなってきたのが現状です。

> `rainbow table` :ハッシュ結果(ダイジェスト)のデータベース

直接的な解決方法の一つは、自

元記事を表示

Golang-構造体にあるパスワードなどのセキュリティ情報をログに出力しないようにする方法

構造体をログに出力する際に、パスワードとかのようなセキュリティ情報を出力したくない場合は、方法の一つは `構造体の埋め込み(Embedded)` 特性を利用することです。

構造体の埋め込みの形は、次のような形になります。

“`go
type 埋め込み構造体名 struct {
フィールド名 型名
フィールド名 型名
}

type 構造体名 struct {
埋め込み構造体名
フィールド名 型名
}
“`

以下のような例で説明しますと、

`RequestSanitized.Password` は `Request.Password` を上書きすることになります。

`Password` を出力したくなければ、あえて`RequestSanitized.Password` を空値にすれば良いです。

“`go
type Request struct {
Name string `json:”user”`
Password string `json:”password”`
}

type RequestSanitized struct {
Requ

元記事を表示

Go言語のerrorにエラー情報を付けて分岐する。

# この文章について

Go言語の`error`はシンプルで`errors.New(“エラーメッセージ”)`で生成することができます。その一方で、エラー内容に応じて分岐するには工夫が必要です。本記事ではGo言語の`error`でエラー内容に応じて分岐する方法を記載します。

例えば、ユーザ情報を取得するREST APIを作ったときに、

– ユーザが見つからないエラーの場合は、404レスポンス
– データベース接続時に不測のエラーがあった場合は、500レスポンス

としたいと思います。JavaやC#等であれば例外クラスのどれをキャッチしたかで判断できます。しなしながら、Go言語ではどちらの場合であってもシンプルな`error`とだけ変えるので判断できません。そこで判断できるように工夫をしましょう。

# 方法1:Sentinel Error

「Sentinel Error」という単語の和訳が分かりませんので、ここでは「Sentinel Error」と書きます。(知っている方がいましたら教えてください。)

これは`errors.New(エラーメッセージ)`をあらかじめ定義しておき、

元記事を表示

OTHERカテゴリの最新記事