<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>VSCode on YAGI BLOG</title>
    <link>https://www.yuyagishita.com/tags/vscode/</link>
    <description>Recent content in VSCode on YAGI BLOG</description>
    <image>
      <title>YAGI BLOG</title>
      <url>https://www.yuyagishita.com/images/top.png</url>
      <link>https://www.yuyagishita.com/images/top.png</link>
    </image>
    <generator>Hugo -- 0.152.2</generator>
    <language>en</language>
    <lastBuildDate>Fri, 09 Dec 2022 01:21:47 +0900</lastBuildDate>
    <atom:link href="https://www.yuyagishita.com/tags/vscode/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Next.js(React),Go kit(Golang)で「SENRYU」を個人開発した</title>
      <link>https://www.yuyagishita.com/indiedev/senryu/</link>
      <pubDate>Sun, 20 Sep 2020 22:04:18 +0900</pubDate>
      <guid>https://www.yuyagishita.com/indiedev/senryu/</guid>
      <description>&lt;p&gt;&lt;img alt=&#34;senryu&#34; loading=&#34;lazy&#34; src=&#34;https://www.yuyagishita.com/img/senryu.png&#34;&gt;&lt;/p&gt;
&lt;p&gt;今回はじめて個人開発でアプリを作りました！！今年の1月に個人開発をしようと考えてから、アプリ企画・技術選定をして、開発途中で作るアプリを変えたりと色々と迷走しましたが、なんとか一区切りつきました！！（8か月ぐらいかかるなんてチンタラやってたなあ（笑））&lt;/p&gt;
&lt;p&gt;開発したアプリや今まで考えていたことなどをまとめます。&lt;/p&gt;
&lt;h2 id=&#34;アプリ概要&#34;&gt;アプリ概要&lt;/h2&gt;
&lt;p&gt;川柳を共有することができるSNSアプリ「SENRYU」を開発しました。&lt;/p&gt;
&lt;h2 id=&#34;機能&#34;&gt;機能&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;ログイン&lt;/li&gt;
&lt;li&gt;ユーザー登録&lt;/li&gt;
&lt;li&gt;ログアウト&lt;/li&gt;
&lt;li&gt;川柳一覧表示&lt;/li&gt;
&lt;li&gt;マイ川柳一覧表示&lt;/li&gt;
&lt;li&gt;川柳投稿&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;フロントエンド&#34;&gt;フロントエンド&lt;/h2&gt;
&lt;h3 id=&#34;nextjsreact&#34;&gt;Next.js(React)&lt;/h3&gt;
&lt;p&gt;フロントエンドにはNext.jsを利用しました。TypeScriptを使ってみたくて、TypeScriptと相性がいいReactを選択して、最近話題のNext.jsにしようと決めました。&lt;br&gt;
Next.jsはルーティング設定が楽だし、SSG, SSR, SPAをページごとに設定できて便利だしと使って良かったなと思っています。ただ、認証はFirebaseやNextAuth.jsを利用して他のSNSアカウントとかでログインする実装にするのが楽だと感じました。&lt;/p&gt;
&lt;h3 id=&#34;material-ui&#34;&gt;Material-UI&lt;/h3&gt;
&lt;p&gt;ReactのUIコンポーネントライブラリであるMaterial-UIを利用してUIの基礎を作りました。簡単に見た目を整えることができるので、とても便利です。&lt;/p&gt;
&lt;h3 id=&#34;styled-components&#34;&gt;styled-components&lt;/h3&gt;
&lt;p&gt;Material-UIの見た目を調整したい時にCCS in JSのstyled-componentsを利用しました。TypeScript内でCSSを書けるので普段CSSとかを書かない僕には使いやすかったです。&lt;/p&gt;
&lt;h2 id=&#34;バックエンド&#34;&gt;バックエンド&lt;/h2&gt;
&lt;h3 id=&#34;go-kitgolang&#34;&gt;Go kit(Golang)&lt;/h3&gt;
&lt;p&gt;個人的にGolangを利用したかったのとマイクロサービス構成でアプリを作ってみたいという理由からGo kitを利用しました。使ってみた感想としてあまり日本語のドキュメントとかなく調べるのが大変でしたが、Golangにはホットリロードがあってコンパイルが速く言語に慣れれば開発スピードが上がりそうだなと思いました。&lt;/p&gt;
&lt;h2 id=&#34;データベース&#34;&gt;データベース&lt;/h2&gt;
&lt;h3 id=&#34;mongodb&#34;&gt;MongoDB&lt;/h3&gt;
&lt;p&gt;NoSQLを利用したことがなかったので今回利用しました。MongoDBの基礎的な知識を身につけることはできましたが、RDBMSよりもNoSQLを利用するメリットがあんまりわからなかったです。&lt;/p&gt;
&lt;h2 id=&#34;開発環境&#34;&gt;開発環境&lt;/h2&gt;
&lt;h3 id=&#34;docker&#34;&gt;Docker&lt;/h3&gt;
&lt;p&gt;マイクロサービス構成でアプリ開発をしていたので、それぞれのサービス毎にコンテナを作成しました。ローカルでDockerコンテナを立てて開発するときはVSCodeのRemote Containerが非常に便利でした。ぜひ使ってみてほしいです。&lt;/p&gt;
&lt;h2 id=&#34;対象リポジトリ&#34;&gt;対象リポジトリ&lt;/h2&gt;
&lt;p&gt;&lt;a href=&#34;https://github.com/yuyagishita/senryu-frontend&#34;&gt;senryu-frontend&lt;/a&gt;&lt;br&gt;
&lt;a href=&#34;https://github.com/yuyagishita/senryu-user&#34;&gt;senryu-user&lt;/a&gt;&lt;br&gt;
&lt;a href=&#34;https://github.com/yuyagishita/senryu-post&#34;&gt;senryu-post&lt;/a&gt;&lt;/p&gt;
&lt;h2 id=&#34;記事を書くまでの経緯&#34;&gt;記事を書くまでの経緯&lt;/h2&gt;
&lt;p&gt;元々、今年の1月に他のサービス開発を考えていました。技術選定の時には&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Next.js(React)&lt;/li&gt;
&lt;li&gt;TypeScript&lt;/li&gt;
&lt;li&gt;Go kit(Golang)&lt;/li&gt;
&lt;li&gt;MongoDB&lt;/li&gt;
&lt;li&gt;Docker&lt;/li&gt;
&lt;li&gt;Github Actions&lt;/li&gt;
&lt;li&gt;AWS&lt;/li&gt;
&lt;li&gt;K8s&lt;/li&gt;
&lt;li&gt;マイクロサービス&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;でアプリを開発してリリースをしようと思っていました。せっかくの個人開発だし勉強もかねて挑戦してやる！っていう気持ちで技術選定をしましたが、今思うとDocker以外はほぼ経験がなかったのでめちゃくちゃ無謀だったなと思います。（笑）&lt;br&gt;
そんな感じで技術選定をしてから要件や仕様決めて開発を始めましたが、わからないことが多すぎで全然進捗がなかったです。。亀の足のような遅さでしたがなんとか進めていた
4月頃か5月頃に気づいてしまいました。&lt;br&gt;
「クラウドでK8s使うと金けっこうかかるやんけ！」&lt;br&gt;
今思うと当たり前だし、調査不足すぎだよ自分。。ということがあり、最初に作りたかったサービスは世にリリースするのが厳しいなと思いましたが、せっかくある程度までは勉強して作っていたので、違うサービスとして開発をしてGithubで公開してポートフォリオ的な感じにしようと決めました。&lt;br&gt;
といった経緯で今に至ります。結果的には個人開発したアプリをリリースすることはできませんでしたが、Next.jsとGolangを学べたり個人開発の雰囲気を味わえたので良かったです。&lt;/p&gt;
&lt;h2 id=&#34;最後に&#34;&gt;最後に&lt;/h2&gt;
&lt;p&gt;個人開発はすべてを自分で考えないといけないので、とても大変ですが技術選定や作業の進め方など誰からも指図されずに好きなようにできるので、楽しいし学びが多いですね。&lt;/p&gt;</description>
    </item>
    <item>
      <title>AtCoder用にPythonの環境構築</title>
      <link>https://www.yuyagishita.com/tech/atcoder/environment-setup/</link>
      <pubDate>Mon, 16 Mar 2020 22:24:26 +0900</pubDate>
      <guid>https://www.yuyagishita.com/tech/atcoder/environment-setup/</guid>
      <description>&lt;p&gt;&lt;img alt=&#34;atcoder-python&#34; loading=&#34;lazy&#34; src=&#34;https://www.yuyagishita.com/img/atcoder-python.png&#34;&gt;&lt;/p&gt;
&lt;p&gt;本記事は以前&lt;a href=&#34;https://qiita.com/yu_yagishita&#34;&gt;Qiita&lt;/a&gt;に投稿した内容を本ブログに持ってきています。&lt;/p&gt;
&lt;h1 id=&#34;はじめに&#34;&gt;はじめに&lt;/h1&gt;
&lt;p&gt;最近、&lt;a href=&#34;https://atcoder.jp/&#34;&gt;AtCoder&lt;/a&gt;を始めました。&lt;br&gt;
AtCoderは競技プログラミングサイトで、毎週リアルタイムのコンテストが開催されていて、AtCoderで評価されたレーティングを利用して、転職活動ができる&lt;a href=&#34;https://jobs.atcoder.jp/&#34;&gt;AtCoderJobs&lt;/a&gt;というサービスが話題になっているそうです。&lt;br&gt;
最初、シェルがfishでHomebrewなどが入っている状態で色々試していましたが、うまくいかなかったので、Mac環境をきれいにして環境構築をしました。&lt;/p&gt;
&lt;h1 id=&#34;環境&#34;&gt;環境&lt;/h1&gt;
&lt;p&gt;&lt;code&gt;macOS Catalina 10.15.2&lt;/code&gt;
&lt;code&gt;Homebrew 2.1.15&lt;/code&gt;
&lt;code&gt;bash 3.2.57&lt;/code&gt;&lt;/p&gt;
&lt;h1 id=&#34;シェルをbashに戻す&#34;&gt;シェルをbashに戻す&lt;/h1&gt;
&lt;p&gt;ターミナルで以下コマンドを叩いて、ターミナルの再起動をするとシェルがbashに戻ります。&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;$ chsh -s /bin/bash
&lt;/code&gt;&lt;/pre&gt;&lt;h1 id=&#34;homebrewをアンインストールする&#34;&gt;Homebrewをアンインストールする&lt;/h1&gt;
&lt;p&gt;以下コマンドを叩いてパスワードを入力すると、Homebrewをアンインストールできます。&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;$ ruby -e &amp;#34;$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/uninstall)&amp;#34;
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;&lt;a href=&#34;https://docs.brew.sh/FAQ&#34;&gt;Homebrewの公式サイト&lt;/a&gt;に記載されています。&lt;/p&gt;
&lt;h1 id=&#34;homebrewインストールする&#34;&gt;Homebrewインストールする&lt;/h1&gt;
&lt;p&gt;以下コマンドを叩く。&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;$ usr/bin/ruby -e &amp;#34;$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)&amp;#34;
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;インストールできたか確認するために、以下コマンドを叩きます。&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;$ brew doctor
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;すると、&lt;code&gt;Warning&lt;/code&gt;が大量に出たので、&lt;a href=&#34;https://qiita.com/6592sho/items/b24766e203fb7a48b056&#34;&gt;brew doctorでWarningが出たので解決方法まとめました。(for Mac)&lt;/a&gt;を参考に解決しました。&lt;br&gt;
&lt;code&gt;Warning: Unbrewed dylibs were found in /usr/local/include.&lt;/code&gt; のログに関しては残すことを忘れてしまっていたので、上記記事を引用しています。&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;Please note that these warnings are just used to help the Homebrew maintainers
with debugging if you file an issue. If everything you use Homebrew for is
working fine: please don&amp;#39;t worry or file an issue; just ignore this. Thanks!

Warning: Unbrewed header files were found in /usr/local/include.
If you didn&amp;#39;t put them there on purpose they could cause problems when
building Homebrew formulae, and may need to be deleted.

Unexpected header files:
  /usr/local/include/arith.h
  /usr/local/include/binary_log_types.h
  /usr/local/include/cdt.h
  /usr/local/include/cgraph.h
  /usr/local/include/color.h
  /usr/local/include/decode.h
  /usr/local/include/demux.h
  /usr/local/include/encode.h
  /usr/local/include/errmsg.h
  /usr/local/include/fcfreetype.h
  /usr/local/include/fcprivate.h
  /usr/local/include/fontconfig.h
  /usr/local/include/freetype/config/ftconfig.h
  /usr/local/include/freetype/config/ftheader.h
  /usr/local/include/freetype/config/ftmodule.h
  /usr/local/include/freetype/config/ftoption.h
  /usr/local/include/freetype/config/ftstdlib.h
  /usr/local/include/freetype/freetype.h
  /usr/local/include/freetype/ftadvanc.h
  /usr/local/include/freetype/ftbbox.h
  /usr/local/include/freetype/ftbdf.h
  /usr/local/include/freetype/ftbitmap.h
  /usr/local/include/freetype/ftbzip2.h
  /usr/local/include/freetype/ftcache.h
  /usr/local/include/freetype/ftchapters.h
  /usr/local/include/freetype/ftcid.h
  /usr/local/include/freetype/ftdriver.h
  /usr/local/include/freetype/fterrdef.h
  /usr/local/include/freetype/fterrors.h
  /usr/local/include/freetype/ftfntfmt.h
  /usr/local/include/freetype/ftgasp.h
  /usr/local/include/freetype/ftglyph.h
  /usr/local/include/freetype/ftgxval.h
  /usr/local/include/freetype/ftgzip.h
  /usr/local/include/freetype/ftimage.h
  /usr/local/include/freetype/ftincrem.h
  /usr/local/include/freetype/ftlcdfil.h
  /usr/local/include/freetype/ftlist.h
  /usr/local/include/freetype/ftlzw.h
  /usr/local/include/freetype/ftmac.h
  /usr/local/include/freetype/ftmm.h
  /usr/local/include/freetype/ftmodapi.h
  /usr/local/include/freetype/ftmoderr.h
  /usr/local/include/freetype/ftotval.h
  /usr/local/include/freetype/ftoutln.h
  /usr/local/include/freetype/ftparams.h
  /usr/local/include/freetype/ftpfr.h
  /usr/local/include/freetype/ftrender.h
  /usr/local/include/freetype/ftsizes.h
  /usr/local/include/freetype/ftsnames.h
  /usr/local/include/freetype/ftstroke.h
  /usr/local/include/freetype/ftsynth.h
  /usr/local/include/freetype/ftsystem.h
  /usr/local/include/freetype/fttrigon.h
  /usr/local/include/freetype/fttypes.h
  /usr/local/include/freetype/ftwinfnt.h
  /usr/local/include/freetype/t1tables.h
  /usr/local/include/freetype/ttnameid.h
  /usr/local/include/freetype/tttables.h
  /usr/local/include/freetype/tttags.h
  /usr/local/include/ft2build.h
  /usr/local/include/geom.h
  /usr/local/include/graphviz_version.h
  /usr/local/include/gvc.h
  /usr/local/include/gvcext.h
  /usr/local/include/gvcjob.h
  /usr/local/include/gvcommon.h
  /usr/local/include/gvconfig.h
  /usr/local/include/gvplugin.h
  /usr/local/include/gvplugin_device.h
  /usr/local/include/gvplugin_layout.h
  /usr/local/include/gvplugin_loadimage.h
  /usr/local/include/gvplugin_render.h
  /usr/local/include/gvplugin_textlayout.h
  /usr/local/include/gvpr.h
  /usr/local/include/lt_dlloader.h
  /usr/local/include/lt_error.h
  /usr/local/include/lt_system.h
  /usr/local/include/mux.h
  /usr/local/include/mux_types.h
  /usr/local/include/my_command.h
  /usr/local/include/my_list.h
  /usr/local/include/mysql.h
  /usr/local/include/mysql/client_plugin.h
  /usr/local/include/mysql/plugin_auth_common.h
  /usr/local/include/mysql/udf_registration_types.h
  /usr/local/include/mysql_com.h
  /usr/local/include/mysql_time.h
  /usr/local/include/mysql_version.h
  /usr/local/include/mysqld_error.h
  /usr/local/include/mysqlx_ername.h
  /usr/local/include/mysqlx_error.h
  /usr/local/include/mysqlx_version.h
  /usr/local/include/pack.h
  /usr/local/include/pathgeom.h
  /usr/local/include/pathplan.h
  /usr/local/include/png.h
  /usr/local/include/pngconf.h
  /usr/local/include/textspan.h
  /usr/local/include/types.h
  /usr/local/include/usershape.h
  /usr/local/include/xdot.h

Warning: Your Xcode (10.3) is outdated.
Please update to Xcode 11.3 (or delete it).
Xcode can be updated from the App Store.

Warning: Broken symlinks were found. Remove them with `brew cleanup`:
  /usr/local/lib/node_modules/expo-cli/node_modules/.bin/detect-libc
  /usr/local/lib/node_modules/expo-cli/node_modules/.bin/prebuild-install
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;まずは、&lt;code&gt;Warning: Unbrewed header files were found in /usr/local/include.&lt;/code&gt;の解決をします。&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
