production.log

ピクスタ株式会社で開発部の部長をやっている星直史のブログです。

bundle install時に--path vendor/bundleを付ける

自分は、bundle installをする時に--path vendor/bundleを付けてプロジェクトごとにgemを管理しているのですが、なぜかこのオプションだけ覚えることができないので、備忘録的に書く

Apache Bench(abコマンド)をmacOSで実行した場合に出るエラー「socket: Too many open files (24)」の回避方法

AWS ELBの暖気申請(Pre-Warming)をしたかったのですが、サポートのプランがBusiness以上でなければ申請できないため、自前でPre-Warmingをする必要がありました。 AWS ELBは負荷が上がった場合に、AutoScaleするLBです。 通常、事前に大量のトラフィックが予…

AWS障害が発生した場合に確認するページやサイトまとめ

2019年8月23日 13時頃からAWS EC2の接続ができなくなる障害が発生しました。 このような大規模障害は滅多にないので、障害の情報収拾する際に「どこみりゃいいんだ?」となるので、この機会にまとめることにしました。この記事ではAWSで障害が発生した場合に…

福島県金山町は玉梨温泉に行ってきました

夏休みに実家の福島に帰ったので、前々から行きたかった金山町の温泉に行くことにしました。 福島県金山町は天然の炭酸が湧出することで有名です。 井戸から炭酸水を汲むこともできますし、温泉にも利用されています。 また、天然炭酸温泉は全体の0.6%という…

群馬県は四万温泉 中生館に行ってきました

初めてだけど、懐かしい。でおなじみの四万温泉ですが、前回の旅行から早一年。静かな温泉地が恋しくなったので、今年も四万温泉に行くことにしました。

SnapmartのブログサーバーのSSL証明書をLet's EncryptからAWS Certificate Manager (ACM)に移管しました

先日、SnapmartのブログサーバーのSSL証明書が有効期限切れになってしまい、アクセスすることができなくなってしまいました。これまでSnapmartのブログサーバーではLet's Encrypt という証明書を無料で発行しているサービスを使っていました。しかし、このLe…

山梨県は、ほったらかし温泉に行ってきました

静岡県はサウナの聖地 サウナしきじにレンタカーを借りて行ったのですが、せっかくなので、帰りは山梨を経由して帰ることにしました。 山梨は有名な温泉地が多数ありますが、中でもほったらかし温泉には以前から行きたいと思っていたので、このタイミングで…

静岡県はサウナの聖地「サウナ しきじ」に行ってきました

ピクスタの温泉番長を名乗っておきながら、サウナの聖地である「サウナ しきじ」に行ったことがないという、モグリでした。 と、いうのも「たかだかサウナでしょ?天然水使ってる銭湯でしょ?変わらないでしょ〜〜〜」と高を括っていたため、行けていません…

【React Native】Expo SDK v33.0.0 へのアップグレード手順

今年の1月にGoogleが「今後Androidアプリは64bit対応してないとダメだよ!8月1日以降32bitのアプリはリリースできないからね!」というアナウンスをしました。SnapmartアプリはReactNativeで実装しており、開発ツールとしてExpoを使っています。ExpoはSDKの…

神奈川県は湯河原温泉 元湯旅館 光陽館に行ってきました

現在ピクスタ株式会社とスナップマート株式会社の両方に携わっているのですが、6/21(金)~22(土)にスナップマートの合宿が湯河原で行われました。 湯河原は9年前に訪れた記憶があるのですが、その時は温泉にさして興味はなかったので、今回は本気で臨むことに…

ReactNative 0.59.8のCameraRoll.getPhotosでInvalid filter option: '(null)'. Expected one of 'photos','videos' or 'all'.が発生した場合の回避方法

タイトルの通り、ReactNative 0.59.8において、`CameraRoll.getPhotos({first:1234})`がエラーになってしまいます。また、これはiOSのみで発生します。エラー文を見た感じ、optionとしてassetTypeに何かしら指定すれば良さそうです。ただ、ドキュメントを見…

AWS IAM ユーザー各自のMFA設定ポリシーの登録

AWS IAMでは、特定のグループにポリシー(権限)を設定し、そのグループにユーザーを追加することで、権限管理が容易になります。設定できるポリシーは、AWSが用意しているポリシーと、独自に設定できるポリシーの2パターンあります。 今回は、AWS IAM ユーザ…

SnapmartにPull Pandaを導入しました

6月18日(火)にGitHubがPull Pandaを買収したと話題になったので、早速Snapmartにも導入しました。今回は簡単にPull Pandaの紹介をします。

Linuxでduコマンドとdfコマンドを使って空き容量を増やす方法

サービスを運用していると、サーバー内のディスク空き容量が枯渇してしまうことがしばしばあると思います。以前「AWS EC2のルートボリューム(EBS)をダウンタイム0で拡張する方法」について書きましたが、対応の一つとして格納されているファイルを整理するこ…

ReactNative版Snapmartアプリ開発の舞台裏

先日、SnapmartのスマホアプリをReactNative + Expoで実装を行いました。ピクスタ開発ブログに書いた内容だと、カッコ良いところしか書けなかった気がするのと、協力してくれた方々について全く触れることができなかったので、この記事では「当時の心境や協…

2年連続で栃木県は喜連川早乙女温泉に行ってきました

ひょんなことからJR東日本在来線のグリーン券が4枚手に入ったので、今年も栃木県は喜連川早乙女温泉に行ってきました。 無料のグリーン券なので、せっかくなら渋谷からグリーン券で行ける最遠の駅が候補になり、その周辺で有名な温泉地帯に行くことにしまし…

ReactNative + Expo製アプリをiOS / Android(Genymotion)エミュレーターで動作させる手順

業務やプライベートでReactNative + Expo製アプリをpullしてきた場合、コードを読むだけではなく、サクッとエミュレーターで動かしたいとことが多くあると思います。 今回は、ReactNative + Expo製アプリをiOS / Android(Genymotion)エミュレーターで動作さ…

SnapmartのWebサーバーにmonitを導入してunicornを不死鳥にした

Webサービスを運営していると、夜中にWebサーバーのプロセスが突然死してしまい、朝に気づくということが多々あります。 流石に人間が24時間365日監視しているのはツラいので、ある特定のプロセスが落ちたら自動で検知と再起動という処理を行いたいです。 今…

特定の名前のEC2のPublicIPを取得する方法

TV放映などで、一時的にスケールアップさせたい時に、オートスケールの機構がなければ職人による技が光ります。 今回は、スポットリクエストで増やしたEC2インスタンスのIPをAWS ESS access policyに登録したかったので、IPを取得する必要がありました。

MySQL Staging環境のDBをdumpしてローカル環境のMySQLにimportする方法

Snapmart社のstagingのDB環境は、AWS RDSを使用しています。 毎日24時にproduction環境のスナップショットからstaging用DBを作成し、update文で個人情報やメールアドレスなどをマスクした状態にしています。 また、stagingが配置されているVPCは社内ネットワ…

vimでsnake_caseをCamelCaseに置換する

RailsとJavaScriptを同時に扱っていると((Style Guideで記法が異なる言語を同時に扱っている場合))、snake_caseからCamelCaseに置換したい時がしばしば訪れます。 一つずつ修正した方が、人間の温かみを感じることができるコードになると思うのですが、置換…

よちよちReactNative #1 を開催しました!

ReactNativeを使い始めたものの、基本的に参考になる記事が少なくて詰みかけてしまったり、英語の記事がメイン(これはまだ良いけど)であったり、参考書が少ないので、初心者にはだいぶハードルが高いなぁと感じていました。 写真者同士で助け合ったり、気軽…

Expo + React Native + TypeScript環境を作る手順まとめ

React Nativeによるアプリ開発では、Expoを使うと中々捗るのですが、2018年11月3日にExpo SDKがv31.0.0にバージョンアップしました。このリリースの大きなポイントとしては、2018年9月にリリースされたReact Native 0.57に対応したことです。 React Nativeは…

Go言語でパッケージを作る方法

Goでスクリプトを書いていると、巨大なmain関数ができてしまったり、1つのファイルに色々な関数がごちゃまぜになることはよくあります。そこで、今回はGo言語のパッケージを作る方法について紹介します。

TreasureDataのCLIで各テーブルのスキーマを取得するためのワンライナー

TreasureDataを運用していて、存在するDBとその中のテーブルのスキーマを一覧で取得したいことがあったので調べて見ました。 GUI上からDBとテーブルを一つずつ確認するのはさすがにツラいのでサクッと見れる方法はこちらです。 `td db:list -f tsv | awk '{ …

LocalStackを使用してGoで書いたLambdaからDynamoDBを呼び出す方法

以前の記事でLocalStackをインストールしました。今回はLocalStackを使用してGoで書いたLambdaからDynamoDBを呼び出す方法を紹介します。

LocalStackのインストールからDocker Composeで動かすまでの手順

以前ServerlessFrameworkでLambdaからDynamoDBを呼び出す処理を書いていました。しかしServerlessFramework単体だと修正, デプロイ, 動作確認のビルドライフサイクルが遅くなる問題があります。 今回は、その問題を解消すべく、LocalStackのインストールから…

OKR(オーケーアール) シリコンバレー式で大胆な目標を達成する方法を読んだ感想や疑問

会社では目標管理の方法としてMBO((Management By Objectivesの略))を使っています。目標管理の手法はMBOの他にもOKRというものが存在することを知ったので、概要を掴むために[OKR(オーケーアール) シリコンバレー式で大胆な目標を達成する方法](https://amz…

技術書典5の戦利品である「完全SIer脱出マニュアル」を読みました

技術書典5の戦利品である「完全SIer脱出マニュアル」を読みました。過去の自分と同じような境遇の人や、SIerに所属しているが、この本を手に取ったら人生が変わる人がいそうだと感じたので、感想を書こうと思います。

Re:VIEWで書いた文章の校正をCircleCIとtextlintでGitHubのPRに自動コメントする仕組み

技術書典でRe:VIEWを使っていたものの、文章を書き、textlintを回すというCI環境を整えることができませんでした。また、このCI環境は、ブログ執筆においても有効であるため、このタイミングで構築することにしました。今回はRe:VIEWで書いた文章をCircleCI…