Parse后台搭建与使用

作者: Samlss | 来源:发表于2019-04-28 11:29 被阅读7次

    什么是Parse?

    官网:https://docs.parseplatform.org/

    Github:https://github.com/parse-community

    • Parse是一个移动后端,最初由提供商Parse Inc开发。该公司于2013年被Facebook收购,并于2017年1月关闭。继2016年宣布即将关闭后,该平台随后开源。 由于托管服务被关闭,Parse Platform已经发展成为一个开源社区,拥有自己的博客,文档和社区论坛。

    • Parse是一个基于云端的后端管理平台。对于开发者而言,Parse提供后端的一站式和一揽子服务:服务器配置、数据库管理、API、影音文件存储,实时消息推送、客户数据分析统计、等等。这样,开发者只需要处理好前端/客户端/手机端的开发,将后端放心的交给Parse即可。目前Parse支持超过50万个App。摘自浅谈 Parse

    • Parse可以让一个作为Android/IOS开发的你,不用后台开发人员配合就可以处理后台数据,并且其有专门的用户系统,消息推送功功能等等,而且API简单易用,虽然坑还是有,但是还是一个很值得Android开发者入手的一个框架。

    Parse目前支持以下平台语言:

    snap_parse_support.png

    服务器搭建

    环境

    • 本人服务器为阿里云CentOs7.4系统服务器
    • XShell6

    这篇文章仅记录Parse后台搭建与在Android中的使用,更详细的使用介绍如果后面有时间还会总结

    首先在root下创建parse目录,然后进入到parse目录

    安装nodejs

    wget https://npm.taobao.org/mirrors/node/v12.0.0/node-v12.0.0-linux-x64.tar.xz
    

    版本看你需要什么版本,建议8.0.0以上,Parse后台需要Node4.3以上版本

    下载完成后可以看到:

    snap_wget_node.png

    解压

    tar -xvf node-v12.0.0-linux-x64.tar.xz
    

    解压后可以看到:

    snap_unzip_node.png

    将原本压缩文件删除

    rm node-v12.0.0-linux-x64.tar.xz  -f
    

    将node-v12.0.0-linux-x64文件夹重新命名为node:

    mv node-v12.0.0-linux-x64/ node
    

    现在该目录下为:

    snap_rename_node.png

    进入到node的bin目录,执行以下命令将node和npm设置为全局命令:

    ln -s /root/parse/node/bin/node  /usr/local/bin/node
    ln -s /root/parse/node/bin/npm  /usr/local/bin/npm
    

    我们 查看 /usr/locl/bin目录可以看到已经成功了:

    snap_node_ln.png

    接着我们可以在终端任何地方通过npm命令下载相关的内容了

    安装MongoDB

    parse服务器后台需要搭配MongoDB,且版本要求为2.6.X,3.0.X,3.2.X

    我们安装3.2.4版本

    首先在parse目录下创建mongodb目录,现在/root/parse目录就有两个目录了:

    snap_parse_dirs.png

    进入mongodb目录,输入下载命令下载压缩包:

    wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.2.4.tgz
    

    下载完成后解压:

    tar -xvf mongodb-linux-x86_64-rhel70-3.2.4.tgz
    

    解压完成后删除压缩包:

    rm mongodb-linux-x86_64-rhel70-3.2.4.tgz -f
    

    现在目录为:

    snap_mongodb_dir.png

    再执行命令将mongodb-linux-x86_64-rhel70-3.2.4目录所有东西剪切到mongodb目录:

    mv mongodb-linux-x86_64-rhel70-3.2.4/* ./
    rm mongodb-linux-x86_64-rhel70-3.2.4/ -rf
    

    最后mongodb目录下为:

    snap_mv_mogodb_dir.png

    在mongodb目录创建一个目录data:

    mkdir data
    cd data  //进入data目录
    
    //创建两个目录
    mkdir db //存放数据文件
    mkdir logs //存放日志文件
    

    再进入到mongodb的bin目录,可以看到该目录下有以下命令文件:

    snap_mongodb_bin.png

    进入到parse-server/bin目录,执行以下命令将mongo设置为全局命令:

    ln -s /root/parse/mongodb/bin/mongo /usr/local/bin/mongo
    

    在这里我们需要创建一个mongodb的配置文件(怎么创建文件不用说了吧😉):

    dbpath = /root/parse/mongodb/data/db
    logpath = /root/parse/mongodb/data/logs/mongodb.log
    port = 27017
    fork = true
    logappend=true
    
    • dbpath:设置数据文件存放目录
    • logpath:设置日志文件的存放目录及其日志文件名
    • port:设置端口号(默认为27017)
    • fork:设置为以守护进程的方式运行,即在后台运行
    • logappend:开启日志追加添加日志

    启动mongodb

    ./mongod --config mongodb.conf 
    
    //下面为成功后的返回
    [root@izj6c0bdyow5dsyv3ptlfez bin]# ./mongod --config mongodb.conf 
    about to fork child process, waiting until server is ready for connections.
    forked process: 1696
    child process started successfully, parent exiting
    

    输入命令查看端口:

    netstat -tunpl
    

    可以看到mongodb已经启动且在监听27017端口:

    snap_mongodb_start.png

    最后在浏览器输入:

    http://{你的服务器ip}:27017/
    

    可以看到以下信息:

    snap_mongodb_connect.png

    注意:如果你用的服务器需要配置网络安全组的话,请到添加一个27017端口的网络安全组,否则该端口没有访问权限。且测试完之后最好关闭该端口的外网访问权限,否则端口有可能被攻击。曾经本人团队由于服务器开启了27017端口的外网访问权限,导致数据库被黑,要给黑客钱才能拿回旧数据,所幸当时处于测试阶段,造成不了什么损失。

    安装Parse后台

    可在任何目录下执行安装parse-server命令:

    npm install -g parse-server
    

    最后会下载在/root/parse/node/lib/node_modules目录下:

    snap_parse_server_install.png

    进入到parse-server/bin目录,执行以下命令将parse-server设置为全局命令:

    ln -s /root/parse/node/lib/node_modules/parse-server/bin/parse-server /usr/local/bin/parse-server
    

    然后启动parse后台服务:

    parse-server --appId APPLICATION_ID --masterKey MASTER_KEY --databaseURI mongodb://localhost/parse &
    
    • mongodb://localhost/parse 配置在mongodb的parse数据库下
    • & 代表让parse-server在后台运行,不阻塞当前终端

    执行成功后可以看到以下信息:

    snap_parse_server_start_success.png

    我们可以执行mongo命令查看数据库:

    mongo
    > show dbs
    
    snap_mongodb_parse_db.png

    安装Parse管理面板

    执行以下命令安装管理面板

    npm install -g parse-dashboard
    

    会下载在/root/parse/node/lib/node_modules目录下:

    snap_parse_dashboard_download.png

    进入到parse-dashboard/bin目录,创建配置文件parse-dashboard.conf(可随便命名):

    {
      "apps": [
        {
          "serverURL": "http://localhost:1337/parse",
          "appId": "myappid",
          "masterKey": "myappkey",
          "appName": "MyApp"
        }
      ],
      "users": [
        {
          "user":"admin",
          "pass":"admin"
        }
      ]
    }
    
    • serverURL:parse服务器地址
    • appid:你的应用id
    • masterKey:你的应用的masterKey
    • appName:应用名称
    • users:管理面板的登录账号

    关于配置文件,目前上面例子只是一个最简单的单个app管理面板,更多相关配置可以看:https://github.com/parse-community/parse-dashboard

    启动parse-dashboard服务:

    ./parse-dashboard --config parse-dashboard.conf --allowInsecureHTTP &
    
    • allowInsecureHTTP:允许远程访问http协议的管理面板
    • & 后台启动,不阻塞当前终端进程

    成功后会提示:

    snap_parse_dashboard_start_success.png

    阿里云这边需要开启安全组允许外网4040端口:

    snap_safety_port.png

    最后,在浏览器输入

    http://{你的服务器ip}:4040/
    

    可以看到以下内容证明配置成功:

    snap_parse_dashboard_login.png snap_parse_dash_board_details.png

    安装总结

    主要需要四步:

    1. 安装nodejs
    2. 安装mongodb
    3. 安装parse-server
    4. 安装pase-dashboard

    使用问题

    我们在终端调用命令:

    parse-server ... //启动parse服务
    parse-dashboard ... //启动管理面板服务
    

    启动parse服务和管理面板服务后,一旦关闭终端,我这里是关闭XShell6,再输入管理面板的ip+端口会发现无法访问,重新连接XShell会发现parse-server进程和parse-dashboard进程都被杀掉了。后面发现,仅仅通过&无法保证在终端中创建的进程不被杀掉,可以通过&+()方式,或者setsid将命令提交后不受本地终端关闭影响。

    Linux 技巧:让进程在后台可靠运行的几种方法

    Android端代码

    在root build.gradle文件添加:

    allprojects {
        repositories {
            ...
            maven { url "https://jitpack.io" }
        }
    }
    

    在你项目例如app下的build.gradle添加:

    dependencies {
        implementation "com.github.parse-community.Parse-SDK-Android:parse:1.20.0"
    }
    

    创建一个用户类:

    @ParseClassName("user")
    public class UserObject extends ParseObject {
        public static String USER_ID = "user_id";
        public static String USER_NAME = "user_name";
    
        public void setUserId(String userId){
            if (userId != null){
                put(USER_ID, userId);
            }
        }
    
        public String getUserId() {
            return getString(USER_ID);
        }
    
        public void setUserName(String userName) {
            if (userName != null){
                put(USER_NAME, userName);
            }
        }
    
        public String getUserName() {
            return getString(USER_NAME);
        }
    }
    
    • ParseClassName注释:类似于数据库中的表名,数据库中会有一个类与当前类匹配

    初始化:

    ParseObject.registerSubclass(UserObject.class);
    Parse.initialize(new Parse.Configuration.Builder(this)
          .applicationId("YOUR_APP_ID")
          // if defined
          .clientKey("YOUR_CLIENT_KEY")
          .server("http://{YOUR_SERVER_IP}:1337/parse/")
          .build()
        );
    
    • ParseObject.registerSubclass:该类只有经过注册了才能使用,会联系parse数据库的user类

    插入数据:

    UserObject userObject = new UserObject();
    userObject.setUserId("10000");
    userObject.setUserName("SamLeung");
    userObject.saveInBackground(new SaveCallback() {
        @Override
        public void done(ParseException e) {
            Log.e("TAG", "save user done: " + e != null ? "success" : e.getMessage());
        }
    });
    
    • e为null则代表无异常,保存成功
    • e不为null则代表异常,保存失败

    执行后可以在DashBoard中看到保存的内容:

    snap_android_sdk_save_success.png

    更多Android端API可参考:https://docs.parseplatform.org/android/guide/

    相关文章

      网友评论

        本文标题:Parse后台搭建与使用

        本文链接:https://www.haomeiwen.com/subject/osqdnqtx.html