OSXでssh-copy-idを使ってリモートサーバにパスワードなしでログインする
OSXでssh-copy-id
を使う方法です。
何ができる?
インストール
beautifulcode/ssh-copy-id-for-OSX - GitHubを使います。
ダウンロード
curl https://raw.githubusercontent.com/beautifulcode/ssh-copy-id-for-OSX/master/ssh-copy-id.sh -o /usr/local/bin/ssh-copy-id
実行権限を付与
chmod +x /usr/local/bin/ssh-copy-id
使い方
公開鍵を生成します。
~/.ssh/id_rsa.pub
が存在する場合は不要です。ssh-keygen
以下が生成されます。
~/.ssh/id_rsa.pub
公開鍵を配布します。
通常
ssh-copy-id [ユーザID]@[リモートサーバ] ssh-id-copy root@192.168.100.10 #例
~/.ssh/id_rsa.pub
以外の公開鍵を使う場合ssh-copy-id -i 公開鍵のフルパス [ユーザID]@[リモートサーバ] ssh-id-copy ~/.ssh/myidentity.pub root@192.168.100.10 #例
※ ログインパスワードを聞かれるので入力します。
sshでリモートのサーバにログインします。
ssh [ユーザID]@[リモートサーバのアドレス] ssh root@192.168.100.10 #例
※ ログインパスワードは聞かれません。
npmに自作のCLIモジュールを公開する
npmのアカウントを作成
https://www.npmjs.orgで登録します。
- ユーザ名
- パスワード
- Emailアドレス
npmコマンドとnpmアカウントの紐付け
先ほど作成したユーザ情報を対話的に入力します。
npm adduser
公開準備 : package.json生成
npm init
でpackage.json
を対話的に生成します。
"private"
がtrue
の場合はfalse
に修正します。
"private": false,
公開準備 : CLIモジュール用の設定
npm install -g
に対応
"preferGlobal": true,
コマンド名と起動コマンドの登録
"bin": {
"コマンド名": "起動スクリプト名"
},
公開
npm publish
確認
npm info モジュール名
バージョンアップ
package.json
のversionを新たなバージョンに変更してnpm publish
します。
GitHubのユーザ名を変更する
GitHubのユーザ名を変更する方法です。過去のコミットのユーザ名やメールアドレスも修正します。
GitHubのユーザ名を変更
Account Settings -> Change username
ローカルのgitのユーザ名を変更
git config --global user.name "新ユーザ名"
git config --global user.name "新メールアドレス"
ローカルのgitリポジトリのリモートリポジトリを変更
ローカルgitリポジトリに移動
cd ローカルgitリポジトリ
過去のURLを表示
git remote -v
新URLを表示
コピペしてユーザ名のみを変更すると楽です
git remote set-url origin https://github.com/新ユーザ名/リポジトリ名.git
過去のコミットの名前を変更
ここからはお勧めできませんがどうしてもという場合
過去のコミットを全て表示
git rebase -i --root
修正したいコミットを選択
修正したいコミットのpickをeditに変更します。
修正前
pick XXXXX pick XXXXX
修正後
edit XXXXX edit XXXXX
vimコピペ用
%s/pick/edit/gc
過去のコミットを修正
ユーザ名とメールアドレスを変更します
git commit --amend --author="新ユーザ名 <新メアド@gmail.com>"
コメントも修正できます
残りのコミットを修正
git rebase --continue
繰り返す
3と4をeditに変更した行だけ繰り返します
GitHubへpush
git push -f
以上
AngularJSでリストやテーブルの各行にボタンを配置する
リストの各行、テーブルの各列、ナビゲーションバーの要素などにボタンやリンクを配置して、クリックされたら各行の内容に応じて処理を行いたいケースがあると思います。このよう場合、ng-repeat
とng-click
を使うとシンプルです。
HTML(jade)
ul li(ng-repeat="element in list") button(ng-click="display(elemenat.name)") Click
$scope.display = function(name){ console.log(name); }
DOMのidなどは使わず素直にAngularJS流でやるのがいいようです。
herokuでnode.jsのexpress4アプリを動かすためのProcfileの書き方
Express4における雛形生成
express4の起動コマンド
Express4ではアプリの雛形をexpress-generatorで生成するようになり、標準の起動コマンドが以下に変更になりました。
npm start
heroku用のProcfile
heroku用のProcfile
の書き方はいろいろありますが、以下のようにコンソールと同じにすると楽です。
web: npm start