vim tips

移動 キー 説明 } / { 次/前の空行へ移動 % 対応する括弧へ移動 Operator と Text Object Operator 説明 c change d delete y yank v visual Text Object は i(inner: 内側のみ)と a(a: 囲み文字も含む)の2種類がある。 Text Object 説明 iw 単語の内側 aw 単語 + 周囲の空白 i" "..." の内側 a" "..." 全体(引用符含む) i( (...) の内側 a( (...) 全体(括弧含む) i{ {...} の内側 a{ {...} 全体(波括弧含む) it HTMLタグの内側 at HTMLタグ全体(タグ含む) 例 説明 ciw 単語を削除して挿入モード di" ダブルクォート内を削除 ya( 括弧ごとコピー 参考文献 なれる! Vimmer

February 1, 2026 · Ken Kato

netrwの操作コマンド

netrw(Neovim内蔵ファイルブラウザ) キー / コマンド 動作 :Ex カレントディレクトリを開く :Vex 垂直分割で開く :Sex 水平分割で開く <CR> ファイル/ディレクトリを開く v 垂直分割で開く o 水平分割で開く t タブで開く % 新規ファイル作成 d ディレクトリ作成 D 削除 R リネーム - 上のディレクトリへ i 表示形式を切り替え ペイン操作 キー / コマンド 動作 :vs ファイル名 垂直分割でファイルを開く :sp ファイル名 水平分割でファイルを開く Ctrl+w h/j/k/l 左/下/上/右へ移動 Ctrl+w c 閉じる Ctrl+w o 他を全て閉じる Ctrl+w = 均等サイズ タブ操作 キー / コマンド 動作 :tabnew 新規タブ :tabe ファイル名 ファイルをタブで開く gt / gT 次/前のタブ :tabclose タブを閉じる

February 1, 2026 · Ken Kato

Kubernetesをv1.30からv1.31にアップグレードした

自宅で運用しているKubernetesクラスターをv1.30からv1.31にアップグレードしました。 kubeadmを使った標準的なアップグレード手順ですが、忘れがちなので備忘録として残しておきます。 公式ドキュメント: https://kubernetes.io/docs/tasks/administer-cluster/kubeadm/kubeadm-upgrade/ コントロールプレーンノードのアップグレード コントロールプレーンノードから順番にアップグレードしていきます。 パッケージリポジトリの変更 まず、yumリポジトリの設定ファイルをv1.31用に変更します。 変更前(v1.30): [kkato@nuc01 ~]$ cat /etc/yum.repos.d/kubernetes.repo [kubernetes] name=Kubernetes baseurl=https://pkgs.k8s.io/core:/stable:/v1.30/rpm/ enabled=1 gpgcheck=1 gpgkey=https://pkgs.k8s.io/core:/stable:/v1.30/rpm/repodata/repomd.xml.key exclude=kubelet kubeadm kubectl cri-tools kubernetes-cni 変更後(v1.31): $ cat /etc/yum.repos.d/kubernetes.repo [kubernetes] name=Kubernetes baseurl=https://pkgs.k8s.io/core:/stable:/v1.31/rpm/ enabled=1 gpgcheck=1 gpgkey=https://pkgs.k8s.io/core:/stable:/v1.31/rpm/repodata/repomd.xml.key exclude=kubelet kubeadm kubectl cri-tools kubernetes-cni 参考: https://kubernetes.io/docs/tasks/administer-cluster/kubeadm/change-package-repository/ kubeadmのアップグレード まずkubeadmパッケージをアップグレードします。 sudo yum upgrade kubeadm --setopt=disable_excludes=kubernetes アップグレード可能なバージョンを確認します。 sudo kubeadm upgrade plan Components that must be upgraded manually after you have upgraded the control plane with 'kubeadm upgrade apply': COMPONENT NODE CURRENT TARGET kubelet nuc01 v1.30.1 v1.31.14 kubelet nuc02 v1.30.1 v1.31.14 kubelet nuc03 v1.30.1 v1.31.14 kubelet nuc04 v1.30.1 v1.31.14 Upgrade to the latest stable version: COMPONENT NODE CURRENT TARGET kube-apiserver nuc01 v1.30.4 v1.31.14 kube-controller-manager nuc01 v1.30.4 v1.31.14 kube-scheduler nuc01 v1.30.4 v1.31.14 kube-proxy 1.30.4 v1.31.14 CoreDNS v1.11.1 v1.11.3 etcd nuc01 3.5.12-0 3.5.24-0 You can now apply the upgrade by executing the following command: kubeadm upgrade apply v1.31.14 アップグレードを実行します。 ...

January 24, 2026 · Ken Kato

GORMの基本的な使い方

最近、Goを勉強していてGORMを触る機会があったので、基本的な部分を調べてみました。 モデル定義 GORMでは構造体をそのままテーブルにマップします。gorm.Modelを埋め込むとIDやCreatedAtなど便利なカラムが自動で付きます。 package main import "gorm.io/gorm" type User struct { gorm.Model Name string Email string `gorm:"uniqueIndex"` Age uint } DB接続とマイグレーション PostgreSQLを例に、DBへ接続し、モデルに沿ってテーブルを自動生成します。dsnは環境に合わせて書き換えてください。 package main import ( "log" "gorm.io/driver/postgres" "gorm.io/gorm" ) func main() { dsn := "host=localhost user=postgres password=postgres dbname=app port=5432 sslmode=disable" db, err := gorm.Open(postgres.Open(dsn), &gorm.Config{}) if err != nil { log.Fatal(err) } // モデルに合わせてテーブルを作成・更新 if err := db.AutoMigrate(&User{}); err != nil { log.Fatal(err) } } CRUD操作 基本的なCRUD操作は以下のように行います。 package main import ( "fmt" "log" "gorm.io/driver/postgres" "gorm.io/gorm" ) type User struct { gorm.Model Name string Email string `gorm:"uniqueIndex"` Age uint } func main() { dsn := "host=localhost user=postgres password=postgres dbname=app port=5432 sslmode=disable" db, err := gorm.Open(postgres.Open(dsn), &gorm.Config{}) if err != nil { log.Fatal(err) } if err := db.AutoMigrate(&User{}); err != nil { log.Fatal(err) } // CREATE: レコードを追加 alice := User{Name: "Alice", Email: "alice@example.com", Age: 28} if err := db.Create(&alice).Error; err != nil { log.Fatal(err) } // READ: 1件取得(主キーまたは条件指定) var user User if err := db.First(&user, "email = ?", "alice@example.com").Error; err != nil { log.Fatal(err) } fmt.Printf("found: %+v\n", user) // UPDATE: 1カラム更新(モデルを指定) if err := db.Model(&user).Update("Age", 29).Error; err != nil { log.Fatal(err) } // DELETE: ソフトデリート(DeletedAtにタイムスタンプが入る) if err := db.Delete(&user).Error; err != nil { log.Fatal(err) } } よく使うクエリの書き方 // 条件付きで複数取得 var users []User db.Where("age >= ?", 25).Order("age desc").Limit(5).Find(&users) // 複数カラムをまとめて更新 db.Model(&user).Updates(map[string]interface{}{ "Name": "Alice Updated", "Age": 30, }) 参考 GORM Official Guides GORM PostgreSQL Driver

January 17, 2026 · Ken Kato

Go 1.22のHTTPルーティング改善について

最近、Goの勉強をしているんですが、その中で Gin・Echo・chi など多くの選択肢があり、どのフレームワーク(ライブラリ)を選ぶべきか迷いました。 そんな中、Go 1.22(2024年2月リリース)から標準ライブラリのhttp.ServeMuxが強化されたことを知りました。 今回は、Go 1.22でのServeMuxの改善点について調べてみました。 これまでのServeMux(Go 1.21以前)の課題 Go 1.21以前のServeMuxには、以下のような制約がありました。 HTTPメソッドを指定できない // Go 1.21以前: HTTPメソッドの区別ができない mux := http.NewServeMux() mux.HandleFunc("/users", func(w http.ResponseWriter, r *http.Request) { // GET、POST、PUT、DELETEなど、すべてのHTTPメソッドがこのハンドラに来る // 自分でメソッドを判定する必要があった switch r.Method { case http.MethodGet: // GETの処理 case http.MethodPost: // POSTの処理 default: http.Error(w, "Method not allowed", http.StatusMethodNotAllowed) } }) このように、メソッドごとに処理を分けたい場合は、自分でswitch文を書く必要がありました。 パスパラメータを扱えない // Go 1.21以前: パスパラメータが使えない // /users/123 のような動的なパスを扱うには、自分でパースが必要 mux.HandleFunc("/users/", func(w http.ResponseWriter, r *http.Request) { // URLからIDを手動で抽出する必要があった id := strings.TrimPrefix(r.URL.Path, "/users/") fmt.Fprintf(w, "User ID: %s", id) }) 完全一致が難しい // Go 1.21以前: /users にアクセスしたかったが、/users/ も /users/abc もマッチしてしまう mux.HandleFunc("/users", handler) // これは /users だけでなく /users/ にもマッチする こうした課題から、多くのプロジェクトでサードパーティのルーターライブラリが使われていました。 Go 1.22での新機能 Go 1.22では、これらの課題を解決する3つの大きな機能が追加されました。 ...

December 29, 2025 · Ken Kato