-
Notifications
You must be signed in to change notification settings - Fork 30
ambari web
https://cwiki.apache.org/confluence/display/AMBARI/Coding+Guidelines+for+Ambari
$ sudo npm install -g [email protected]
npm: relocation error: npm: symbol SSL_set_cert_cb, version libssl.so.10 not defined in file libssl.so.10 with link time reference
google到这个网页的办法:
$ yum-config-manager --enable cr && yum update
这导致yum可以安装未正式发布的测试包。
之后虽然可以安装了,但很慢,创建一个使用淘宝NPM镜像的别名:
$ alias cnpm="npm --registry=https://registry.npm.taobao.org \
--cache=$HOME/.npm/.cache/cnpm \
--disturl=https://npm.taobao.org/dist \
--userconfig=$HOME/.cnpmrc"
$ sudo cnpm install -g [email protected]
运行cnpm install
时提示phantomjs没有在路径上,手工下载phantomjs,并添加到PATH:
$ cd /opt
$ wget https://github.com/Medium/phantomjs/releases/download/v2.1.1/phantomjs-2.1.1-linux-x86_64.tar.bz2
$ tar -xjf phantomjs-2.1.1-linux-x86_64.tar.bz2
$ export PATH=$PATH:/opt/phantomjs-2.1.1-linux-x86_64/bin
根据社区文章:https://community.hortonworks.com/questions/26377/how-can-i-build-hdp-for-source.html 从github上下载HDP的ambari源码包: https://github.com/hortonworks/ambari-release/archive/AMBARI-2.5.1.7-tag.zip
按Ambari Web Frontend Development Environment的办法进行构建,并启动:
$ brunch watch --server
登录ambari UI后报错,发现少了info.json
文件。自己造一个:
$ cd app/assets/data/clusters
$ vi info.json
{
"items" : [
{
"Clusters" : {
"cluster_name" : "cc",
"provisioning_state" : "INSTALLED",
"version" : "HDP-2.4.3"
}
}
]
}
重新启动brunch watch --server
后问题解决!
ambari的api文档以swagger.json的方式提供。在ambari-web目录看到一个api-docs目录,这个目录是swagger显示引擎的目录。可以将nginx的根目录设置到这里。
$ nginx -t
nginx: the configuration file /usr/local/openresty/nginx/conf/nginx.conf syntax is ok
编辑上面的nginx.conf文件:
server {
listen 80;
server_name localhost;
location / {
root /opt/ambari/ambari-web/api-docs;
index index.html index.htm;
}
}
然后找到ambari的swagger.json文件:
$ find /opt/ambari -name swagger.json
/opt/ambari/ambari-server/docs/api/generated/swagger.json
$ cp /opt/ambari/ambari-server/docs/api/generated/swagger.json /opt/ambari/ambari-web/api-docs
$ nginx -t
$ nginx
$ curl localhost
假设这个linux虚拟机的ip是:192.168.73.102。则在windows下用浏览器访问地址http://192.168.73.102
就可以用swagger阅读ambari API文档了。
原文
安装Ember.js。用npm很慢,cnpm快很多。
$ cnpm install -g [email protected]
创建一个新应用,按原文的办法使用npm安装依赖包很慢。改进后的办法是:
$ ember new --skip-npm ember-quickstart
$ cd ember-quickstart
$ cnpm install
这样就是使用cnpm安装依赖包,怀疑能快10倍。
启用开发服务器:
$ ember serve
用浏览器访问http://c7302.ambari.apache.org:4200
就可以看到刚创建的Ember应用的欢迎页。
编辑app/templates/application.hbs
为下列内容:
<h1>PeopleTracker</h1>
{{outlet}}
重新执行ember serve
,然后可以看到欢迎页变了。
- visit - loads a given URL
- click - pretends to be a user clicking on a specific part of the screen
- andThen - waits for our previous commands to run before executing our function. In our test below, we want to wait for our page to load after click is called so that we can double-check that the new page has loaded
- currentURL - returns the URL of the page we're currently on
Mustache是一个无逻辑模板语言。称无逻辑,因为它的定义中没有循环、判断等语法,只有标签。
官网:http://mustache.github.io。
官方只提供了RUBY实现,但大量爱好者提供了各种语言的实现。其javascript的实现在github上有一万多颗星。
Mushtache的语法在官网的这个链接。
github home
handlebars.js是Mustache的超集,和javascript实现。
handlebars.js的增强部分:
- 内部路径,可以访问json串内部属性,如
{{author.name}}
- helpers。在mustache的体系下,可以在json串中嵌入代码(Lambda),把数据和代码放在一起有些怪。handerbars.js以helper代替,helper对代码的调用显式定义在模板中,格式类似
{fullName author}}
。fullName
就是一个helper。 - 块表达式(mustache称为
Section
)。增强了mustache的section,使块也支持helper。格式类似{{#fillName author}}
。