跳到主要內容

Coinhive 挖礦教學 - Javascript 網頁挖礦,讓瀏覽者幫網站主挖礦賺取門羅幣 Monero (XMR)




(6/24) 目前「台灣 Monero 礦池」亦提供 Javascript 網頁挖礦服務,延遲低、手續費優惠且針對網頁挖礦優化,詳細使用和程式碼可以參考這裡



Coinhive 提供了讓網站主在自己的網頁置入挖礦程式挖取門羅幣 Monero (XMR),做以取代傳統網頁廣告像 Google Adsense 的投置廣告,隨著 AdBlock 的普及,投放廣告早已經賺不到太多的收入,而且廣告費談判也極度失衡,完全被第三方綁架,非常不符合去中心化的概念,因此產生出了這種以網頁挖礦代替廣告的方式,借用瀏覽者部分的 CPU 效能 (不使用顯卡) 來幫網站主直接賺取虛擬貨幣收益,本站也同樣選用 Coinhive 代替網頁廣告,或許你有發現也或許沒有,但實質上造成的影響其實遠沒有想像中的大,隨著電腦配備的進步,瀏覽網頁已經是電腦的最基本功能,大部分電腦的效能在看網頁上都是遊刃有餘,只要有相關的停止措施和對行動裝置優化,我認為網頁挖礦對使用者帶來的影響反而比廣告更小。



預設的挖礦 GUI



Coinhive 網頁挖礦


  • 官網 : https://coinhive.com/
  • 挖礦幣別 : 門羅幣 Monero (XMR)
  • 起付額 : 0.02 XMR (0.5 XMR免手續費)
  • 收益算法 : (<solved_hashes>/<global_difficulty>) * <block_reward> * 0.7



可以看到 Coinhive 會抽取三成的收益,官網提到是為了支援維護費用,可以在 FAQ 裡面詳讀。但必須說我用 Coinhive 至今只碰過一次伺服器維修了幾個小時,他們也馬上在面板上發公告致歉,而且用推算的算力補足這段時間的收益,我會覺得這樣的服務品質還算值得。




註冊 (https://coinhive.com/account/signup) 完後就可以到 Settings>Sites & API Keys 建立密鑰,不同網站可以共用一個 key 沒關係,Secret Key記得不要讓他人知道,如果洩漏了可以按 revoke 重新產生。


Documentation 選擇適合自己網站的程式碼(https://coinhive.com/documentation),基本上它分為幾種,個人網站會選用的大概就是最簡單的 Simple Miner UIJavaScript Miner,如果是使用 WordPress 的用戶也可以直接裝 Plugin



最簡單的 Simple Miner UI :

<script src="https://authedmine.com/lib/simple-ui.min.js" async></script>
<div class="coinhive-miner" 
 style="width: 256px; height: 310px"
 data-key="RQjZrjeqqcG1UU4rSLBkQwKBv0oki9hZ">
 <em>Loading...</em>
</div>

基本上只要把 data-key 換成剛剛產生的 key 就可以使用了,當然它還有許多參數可以更改,如下 : 

<script src="https://authedmine.com/lib/simple-ui.min.js" async></script>
<div class="coinhive-miner" 
 style="width: 256px; height: 310px"
 data-key="RQjZrjeqqcG1UU4rSLBkQwKBv0oki9hZ"
 data-autostart="true"     /*自動開始*/
 data-whitelabel="false"   /*顯示標籤*/
 data-background="#000000" /*背景顏色*/
 data-text="#eeeeee"       /*文字顏色*/
 data-action="#00ff00"     /*動作顏色*/
 data-graph="#555555"      /*圖形顏色*/
 data-threads="4"          /*執行緒*/
 data-throttle="0.1">      /*保留的效能*/
 <em>Loading...</em>
</div>
結果就是像下面的介面。

Loading...


JavaScript Miner 更適合進階使用者,它有更多的細節和自訂介面可以設定。

這邊提供本站使用的附有開始停止和統計 hashes 的 JavaScript :

<script src="https://coinhive.com/lib/coinhive.min.js"></script><center>
<p style="font-size: 11pt;" id="status"></p>
<p style="font-size: 11pt;" id="hashesPerSecond"></p>
<p style="font-size: 11pt;" id="getTotalHashes"></p>
<p style="font-size: 11pt;" id="stopped"></p>
<p id="minerbutton"></p></center>
<script>
if (navigator.hardwareConcurrency > 1){
 var cpuConfig = {threads: Math.round(navigator.hardwareConcurrency-1)}
}else{
 var cpuConfig = {throttle:0.5}
}
var miner = new CoinHive.Anonymous('RQjZrjeqqcG1UU4rSLBkQwKBv0oki9hZ', cpuConfig);
miner.start(CoinHive.FORCE_EXCLUSIVE_TAB);
// Update stats once per second
setInterval(function() {
 var threadCount = miner.getNumThreads();
 var hashesPerSecond = Math.round(miner.getHashesPerSecond());
 var getTotalHashes = miner.getTotalHashes();
try {
 navigator.getBattery().then(function (battery) {
  if (battery.level < 0.50 && battery.charging == false) {
   miner.stop();
   document.getElementById("stopped").innerHTML = "Low Battery";
  }
 });
}catch(e){console.log(e)}
 // Output to HTML elements...
 if (miner.isRunning()) {
  document.getElementById("status").innerHTML = "Status : Using " + threadCount + " threads";
  document.getElementById("hashesPerSecond").innerHTML = "Hashrate : " + hashesPerSecond + " H/s";
  document.getElementById("getTotalHashes").innerHTML = "Total : " + getTotalHashes + " Hashes";
  document.getElementById("minerbutton").innerHTML = "<button onclick=\"miner.stop()\">Stop Mining</button>";
 }else{
  document.getElementById("status").innerHTML = "Status : n/a";
  document.getElementById("hashesPerSecond").innerHTML = "Hashrate : " + 0 + " H/s";
  document.getElementById("minerbutton").innerHTML = "<button onclick=\"miner.start(CoinHive.FORCE_EXCLUSIVE_TAB)\">Continue Mining</button>";
 }
}, 800);
</script>
它會自動偵測系統的 threads 數,並保留一個 thread 不進行挖礦以及只耗用一半的效能,以及電量不足或在充電時會自動停止挖礦,只要將 key 改成自己的就可以使用了,實際執行的樣子可以見本站右上方的介面。





而 Coinhive 提供的 Capcha 則是提供類似轉址和 proof of work 的功能,也順便解開一定量的 hashes 回饋建立連結的人,可以在 Capcha 頁面Shortlinks 找到適合自己網站使用的功能。




留言

張貼留言



這個網誌中的熱門文章

Linux (Ubuntu) 查詢硬碟容量、剩餘大小指令

在 Ubuntu Desktop 版本或有安裝 GUI 像 Xfce 的 Server 版本當然可以直接從圖形介面查看硬碟容量和已經使用的大小, 但如果是在純 CLI 版本或使用 SSH 連線時呢?那就需要用到指令了。 顯示硬碟容量、已使用、可用大小。 df -h 查詢資料夾所占硬碟的大小。 du -h 查詢檔案大小 ls -l

RealVNC - 支援多系統的 VNC Viewer,免費遠端桌面客戶端 (Windows / Linux (Ubuntu) / Raspberry Pi /...)

對於不熟悉 SSH 介面的使用者來說可能第一個想法都會是使用遠端桌面,但要知道大多數的 VPS 主機都是提供 Linux 系統 (Ubuntu / RedHat / Debian...等),它們架好的 VNC Server 多半是沒辦法直接以 Windows 系統內建的「遠端桌面連線」來操作的,就好像兩端的通道是開了起來但卻仍說著不同的語言,所以就需要專用的 VNC Viewer 來連線, 而 RealVNC 支援非常多不同的作業系統環境,包括 Windows、Linux、Raspberry Pi、Android、iOS...等,幾乎可以說是一應具全啦。 RealVNC 官方網站:  https://www.realvnc.com/en 下載頁面:  https://www.realvnc.com/en/connect/download/viewer 只要從 「File > new connection」 就可以新增一個連線,爾後只要點選介面中已設定好的連線就可以隨時進入遠端主機,而主機端 (VPS) 也記得要先架設好 VNC Server 和新增防火牆例外,避免被拒絕的連線。

如何將 ISO 檔上傳到 VMware ESXi 6.5 並且用虛擬光碟開機?適用於安裝 Linux 或其它作業系統

在將實體機器使用  VMware ESXi 6.5 虛擬化之後就可以在它所提供的網頁管理介面操作每個虛擬個體,但要怎麼把用來安裝系統的 ISO 檔傳到虛擬機呢?而這些 ISO 檔會需要做成開機隨身碟的模式才能用嗎? 其實 ESXi 6.5 可以直接建立一個虛擬光碟機來驅動安裝系統用的 ISO 檔 ,所以安裝起來甚至會比實體機更簡單方便。 首先進到 ESXi 的管理介面 > 儲存區 ,點選 資料存放區瀏覽器 。 然後就能上傳事先下載好的 ISO 檔,不一定要存在哪一層路徑或特定位址,但建議新開一個資料夾方便整理,之後也可以直接指定這個路徑內的 ISO 檔。 然後在 虛擬機電源關閉 的情況下進入編輯設定。 新增一台 CD/DVD 光碟機。 選擇資料存放區 ISO 檔案。 瀏覽到剛剛上傳 ISO 檔的位址。 並且在虛擬機器選項的地方強制在 下次開機時強制進入 BIOS 設定畫面。 然後啟動虛擬機電源並開機後 到 Boot 的地方將 CD-ROM Drive 順位提高 ,就能以剛剛掛載的虛擬光碟機開機了。