跳到主要內容

fig 使用方法,打造 node.js 開發環境

fig 使用方法,打造簡單 node.js 開發環境

enter image description here
昨天透過兩三天的時間摸所 docker ,感覺上是非常有趣的一個工具,但是始終不知道這樣子根自己寫 shell script install 的方法有那些差異,透過詢問朋友 / 同事之後才發現,原來 docker 有許多種不同使用情境,所以目前看到許多不同使用方法。
在這麼多不同使用方法中,我只主要目的是解決 非技術 相關人員,可以快速設定開發環境,透過一個指令隨時可以啓動,關閉服務,(畢竟現在開發環境已經要同時啓動好多不同服務),透過 docker 感覺可以做到這件事情,同時我們也可以在每個服務更新的時候進行小元件 / 服務的抽換,對於整體開發人員來說,就不需要考慮環境問題,還能夠統一大家開發工作環境上。
因此這邊透過朋友詢問到 fig, 透過一個晚上的快速時光,把 fig 大致上設定好,也大概搞清楚怎麽使用。

情境

以下是基於一個基本的 node.js http 服務,搭配 fig & docker.
程式碼擺放位置 fig node.js simple server example, 歡迎自由取用。
Fig 的使用方法,我的環境是 MacOS ,因爲要採用到 fig 的 mount 功能,因此採用 docker-osx ,
安裝步驟需要先安裝 virtaulbox and vargant.

安裝 docker-osx

提醒,記得安裝完之後要設定 docker host, 在自己的 .profile, .bashrc 底下加入
eval `docker-osx env`
啓動服務的方式就是
docker-osx start
停止
docker-osx halt

install fig

fig 的安裝步驟, fig installation

fig

進入重點,fig 的使用只需要一個 fig.yml 還有加上一個基本的 Dockerfile, 基本上就是設定一個 master service 在 fig.yml ,透過這個 master service 再跟其他 service / image 進行溝通。
fig.yml,
web:
  build: .
  command: node /myapp/index.js
  volumes:
    - .:/myapp
  ports:
    - "3000:3000"
接下來就是要設定 Dockerfile, 你會發現 Dockerfile 非常簡單,基本上你根本可以不用在乎 docker container 的 os 是什麼環境,只要能夠動就好(理論上),可以在 docker hub 找到更多資料
Dockerfile,
FROM dockerfile/nodejs

usage

以上都設定好之後,可以透過以下指令啓動服務
fig run web
當然你也可以在背景執行
fig run -d web
或者把目前的資料轉成 docker image
# build a docker image
fig build

結論

一開始其實自己也搞不懂 docker 到底可以幫忙做到那些程度,隨着不斷的測試還有朋友,同事一起幫忙之後,發現越來越有感覺,雖然自己只是一個網站開發人員,不過能夠瞭解到另外一個世界的工具其實還蠻有樂趣的。
fig 可以說補足 docker 所不足的部分,docker 是採用小巧的服務環境, fig 就是把這些服務完整連結起來的方式。他可以很快的設定到連接不同 docker image ,這對於開發機上的使用,已經很貼近我的需求,接下來只要把不同服務整合在一起即可。
there is my fig node.js simple server example, you can fork and clone by yourself.

留言

這個網誌中的熱門文章

面試者如何挑戰大工程師時代來臨?

面試者如何挑戰大工程師時代來臨? 全世界都在倡導轉職成為工程師,似乎轉職成為工程師就成為職場的救贖,真的是如此嗎?讓老衲來杠給各位聽。 最近有位好久不見的小朋友,是 2000 年出生的小蔡,對於即將面臨到面對職場的挑戰開始關心起技術,他開始尋找比較適合自己的領域,同時也開始在思考到底為了接下來的就職小蔡該如何準備。 詢問我說是不是可以考慮軟體開發工程師這條路線 對於他的詢問,反而引起我的注意, 這讓我開始思考並映射於最近招募的經驗,軟體開發此領域是不是對於每個人都是可以擔任的職啀,這邊分享一些自己的看法希望對各位有所幫助。 全民工程師這件事情 在全球景氣低迷的狀況下,的確特別在這一年大家會很有感覺萬物齊漲,薪水不漲,薪資就是一直停滯不前。 很多時候,在不同的領域中,會發現整個薪資就算是擔任了管理職務主管你也會面臨到薪資的強大屏障在自己面前。 這個時候, 軟體工程師年薪百萬口號 似乎就成了一種救贖。 好像成為了工程師就可以達到年薪百萬,在家輕鬆工作,不用打卡也不用受到風吹雨淋,隨時想工作就可以工作,每個月又有固定薪水入帳,感受到類財富自由,人生的美好。 如果能夠爭取到跨國公司的職位,這份薪水有可能還可以上看每個月十多萬以上,甚至是往上也是極度有可能的事情,人生美好層次又再度提高了起來。 但這件事情是真的每個人都可以達到嗎? 還是這就是另外一種性存者偏差呢? 亦或者這些人其實是金字塔頂端的小眾? 每份履歷都像是同一種履歷 最近在最近幾年在面試工程師的時候特別會看到許多轉職者,一開始履歷裡面看到相關的作品一開始會覺得十分的驚艷, Wow, 現在的新手就可以做到如此精美的畫面,這些畫面是我當初用 Bootstrap 也做不出來的東西,許多的互動體驗好的一個不行,做出來的頁面配色和對齊也是極致。 但是隨著時間推移,多看了幾封履歷之後,就會發現在各大技術養成學院出來的學生履歷成果內容如出一轍,在面試的過程中也會詢問許多關於框架的底層概念,和比較技術觀念的時候,甚至是許多框架的核心概念,就很容易露出馬腳。 很多面試者會 一問三不知 ,透過許多引導,但殘酷的是連關鍵字是什麼都也無法推敲出來,更不用說在小組裡面到底怎麼樣合作,許多不同線上產品的比較,使用者流程,使用者後面的互動邏輯等,幾乎是風吹一片倒,只能

jQuery, animate function with css exlapenation.

Today, I want to use jQuery making a animation for webpage, First I check animate fuction on ref book. I clearly know how use it, there are two main function for animate. 1. $().animate({ "style1":"value1" , "style2":"value2" }, Time); Time: it can be three type, String => "slow", "fast", "normal". Integer=>10000 2. $().stop(); it can immedaitely stop animation. Let's do some experieces, I bulit a simple page. You can hover UP and DOWN for a article sliding UP or DOWN. Les't do it. HTML CODE: <div id="all"> <div id="up">往上</div> <div id="showTab"> <div id="data"> About This script is intended for forms where the user needs to upload an image to a Web site. The image is displayed on the page for previewing before uploading. The display will be resized if needed so as not to break the page layout. Valid file types are set in the scri

初探 LangChain:語言模型應用程式開發的強大框架

LangChain 是一個強大的框架,致力於幫助開發人員利用語言模型構建端到端的應用程式。它提供了一整套工具、組件和接口,大大簡化了創建由大型語言模型(LLM)和聊天模型支持的應用程式的過程。LangChain 可以輕鬆地管理與語言模型的互動,將多個組件連接在一起,並集成額外的資源,例如 API 和資料庫。 LangChain https://python.langchain.com/en/latest/index.html 不說廢話,直接開始試著安裝, pip install langchain pip install openai export OPENAI_API_KEY="..." 以下是一些 LangChain 的簡單程式碼: import os os.environ["OPENAI_API_KEY"] = "..." from langchain.llms import OpenAI from langchain import OpenAI, ConversationChain from langchain.agents import initialize_agent from langchain.agents import load_tools from langchain.chains import LLMChain from langchain.prompts import PromptTemplate prompt = PromptTemplate( input_variables=["product"], template="What is a good name for a company that makes {product}?", ) print(prompt.format(product="colorful socks")) # What is a good name for a company that makes colorful socks? 在 LangChain 中,開發人員可以使用 LLM、Chat Model、Agents、Chains、Memory