利用NextCloud配置私有云,在U盘下安装ubuntu系统

在U盘下安装ubuntu系统,从U盘启动Linux系统,ubuntulinux

如果我们直接在我们的硬盘上安装Linux系统的话,那么Linux的GRUB就会覆盖window的启动引导项。并且不方便携带。所以我就想在U盘上安装一个ubuntu的系统,可以在任意电脑上启动。

准备工作:

一个32G的U盘(作为系统盘),8G的U盘(作为安装盘),一个ubuntu的ISO文件,还有一个UltraISO软件。

1.下载ubuntu的ISO文件:(如果有的话,就可以直接看第二步)

1)在浏览器上输入“ubuntu下载”之后,第一个就是:按照下面的流程:

2)单击URL链接,就会出现下面的界面

3)。

单击Ubuntu Kylin(就是ubuntu的麒麟版本),或者Ubuntu
Server版本,就会出现下面的页面:

4)

有64位的版本,和32位的版本。单击之后就会下载ubuntu的ISO文件。

2.制作ubuntu的安装盘,即安装Ubuntu的启动盘:

1)打开
UltraISO软件(以管理员的方式),然后选择“文件”——>“打开”,选择刚刚下载的ubuntu的ISO文件。如下图所示:

2)选择“启动”——>“写入硬盘映像”,就会弹出一个对话框:

3)在弹出的对话框中,a.“硬盘驱动器”:选择8G的U盘。b.“写入方式”:USB-HDD+,c.单击写入,即可。

3.安装Ubuntu系统在U盘上:

1)将两个U盘8G和32G的U盘插上电脑上,重启电脑。按照你的电脑品牌进入BIOS。有的选择F2,F12等等不相同。

2)选择哪个“BOOT”的选项。将第一个启动项改成:8G的那个U盘的名称(选择)。我的U盘是金士顿的,那么前面几个开头的就是“”KING……”。

3)保存并退出。选择“SAVE”选项。下面有一个“保存并退出”和一个“不保存退出”。选择“保存退出”。自动就会重启。并进入到Ubuntu的安装界面。

4)就会出现4个选项,选择第二个选项,因为第一个选项是让你体验的(Try开头的)。第二个表示立即安装(Install开头的)。

5)然后就是选择语言:

6)设置无线:用于安装软件的,不然只有安装好自行安装(也可以)。你可以使用手机开一个热点。一般就是一百多M。

7)选中第一个复选框,安装相应的软件:

8)单击继续,就会出现一个对话框。可能没有,有的话选择“退出”。

9)选择“自定义安装”选项,如果选择第一个,就会修改本机电脑的启动项,每次启动要插U盘,并且不能插入其他电脑上启动。单击继续,就会进入分区界面:

10)我们有一个32G的U盘就会出现,一般是sdc的开头。sda一般是你的本地电脑:代表的是你自己电脑上的硬盘,里面有分区不要动,不然数据会就不见。选中你那个sdc的空闲选项,单击“+”。

11)输入主分区的大小(不要分完,分个20G容量,20480M),选择主分区,选择选项就选默认的EXT4日志文件系统,“挂载点”选择第一个,也就是“/”。

12)选中空闲之后,单击+号,选择逻辑分区,输入容量为200M,选择默认的EXT4日志文件系统,“挂载点”选择/boot.

13)选中空闲之后,单击+号,选择逻辑分区,输入容量为4096M,选择交换空间.

14)选择空闲之后,单击+号,选择逻辑分区,输入容量为就是剩下的(不用输入),选择默认的EXT4日志文件系统,“挂载点”选择/usr.

15)重要的一点:“安装启动引导器的设备”选择成你的U盘,选择/dev/sdc就可以了。默认的是dev/sda,不要选择这个,不然数据就会没有。然后单击安装。就会弹出个对话框,显示格式化那些内容,看看有没有你的/dev/sda(一定要没有)。一般出现格式/dev/sdc,这个是当然的。应为你要安装到那个上面。

16)选择时区(一般SHANGHAI)。

17)选择语言。

18)输入登录名和秘密。

19)就是安装。安装完之后就会出现重启机器。

20)重启之后,选择启动项是哪个32G的U盘。或者将8G的U盘拔掉。

*************************************************************************************

注意:如果Boot选项中没有32G的U盘选项,那就到“SAVE&EXIT”选项,也有一个Boot,选择哪个32G的U盘选项。我的电脑Boot就没有32G的U盘就没有,折腾的老半天,就随机的试了后面“SAVE&EXIT”选项,也有一个Boot,没想到成功了。

利用NextCloud配置私有云,nextcloud私有云

首次在远程主机中部署WEB应用,首次主机部署web

利用NextCloud配置私有云

  • 利用NextCloud配置私有云
    • 安装MariaDB
    • 为NextCloud创建数据库和用户
    • 安装PHP和相关模块
    • 下载NextCloud
    • 安装配置Nginx
    • 完成安装

NextCloud () 是开源云盘服务器,此处利用 LEMP 搭建
NextCloud 运行环境-MariaDB, PHP-FPM 和 Nginx (Ubuntu 16.04)

首次在远程主机中部署WEB应用:

​ 1. 打开shell,并且保证能与remote host连接成功;

1. 安装MariaDB

Ubuntu 16.04 安装 MariaDB

更新升级系统:

$ sudo apt update
$ sudo apt upgrade

安装MariaDB:

$ sudo apt install mariadb-server

启动MariaDB服务:

$ sudo systemctl start mysql

查看状态:

$ sudo systemctl status mysql

执行初始化安全脚本,默认root密码为空,设置root密码和其他选项:

$ sudo mysql_secure_installation

安装jdk;

​ 注:如果要安装1.8的jdk,那么需要自己在官网下载sudo apt-get install
default-jre这个命令最新是1.7的;

2. 为NextCloud创建数据库和用户

创建数据库nextcloud;用户名nextcloud,密码XXXXXXXX

$ sudo mysql -u root -p
MariaDB [(none)]> CREATE DATABASE nextcloud;
MariaDB [(none)]> GRANT ALL PRIVILEGES ON nextcloud.* TO 'nextcloud'@'localhost' IDENTIFIED BY 'XXXXXXXX';
MariaDB [(none)]> FLUSH PRIVILEGES;
MariaDB [(none)]> \q
1. 打开终端,使用下面的命令:
java -version

如果你看到像下面的输出,这就意味着你并没有安装过Java:

The program ‘java’ can be found in the following packages:
*default-jre
* gcj-4.6-jre-headless
* openjdk-6-jre-headless
* gcj-4.5-jre-headless
* openjdk-7-jre-headless
Try: sudo apt-get install

3. 安装PHP和相关模块

$ sudo apt-get -y install php-fpm php-cli php-json php-curl php-imap php-gd php-mysql php-xml php-zip php-intl php-mcrypt php-imagick php-mbstring

配置PHP:

$ sudo sed -i "s/memory_limit = .*/memory_limit = 512M/" /etc/php/7.0/fpm/php.ini
$ sudo sed -i "s/;date.timezone.*/date.timezone = UTC/" /etc/php/7.0/fpm/php.ini
$ sudo sed -i "s/;cgi.fix_pathinfo=1/cgi.fix_pathinfo=1/" /etc/php/7.0/fpm/php.ini
$ sudo sed -i "s/upload_max_filesize = .*/upload_max_filesize = 200M/" /etc/php/7.0/fpm/php.ini
$ sudo sed -i "s/post_max_size = .*/post_max_size = 200M/" /etc/php/7.0/fpm/php.ini

重启PHP-FPM:

$ sudo systemctl restart php7.0-fpm
2.
安装jre
    打开终端,使用下面的命令安装JRE :
    sudo apt-get install default-jre
安装OpenJDK
在Ubuntu和Linux Mint上安装OpenJDK

在终端,使用下面的命令安装OpenJDK Java开发工具包:
    sudo apt-get install default-jdk
特殊地, 如果你想要安装Java 8, Java 7或者Java 6等等,你可以使用openjdk-7-jdk/openjdk-6jdk, 但是记住在 此之前安装openjdk-7-jre/openjdk-6-jre

4. 下载NextCloud

$ cd /tmp
$ wget https://download.nextcloud.com/server/releases/nextcloud-12.0.0.zip

解压到 /var/www/ 目录并更改权限:

$ unzip nextcloud-12.0.0.zip
$ sudo mkdir /var/www/
$ sudo mv nextcloud /var/www/
$ sudo chown -R www-data: /var/www/nextcloud
3.通过以上步骤,JDK已安装完成。
通过以上步骤,JDK已安装完成。
输入以下命令验证java -version, 如下(表示安装成功了):
    java version "1.7.0_121"
    OpenJDK Runtime Environment (IcedTea 2.6.8) (7u121-2.6.8-1ubuntu0.14.04.3)
    OpenJDK 64-Bit Server VM (build 24.121-b00, mixed mode)

5. 安装配置Nginx

$ sudo apt-get install nginx nginx-extras

生成自签名证书:

$ sudo mkdir -p /etc/nginx/ssl
$ cd /etc/nginx/ssl
$ sudo openssl genrsa -des3 -passout pass:x -out nextcloud.pass.key 2048
$ sudo openssl rsa -passin pass:x -in nextcloud.pass.key -out nextcloud.key
$ sudo rm nextcloud.pass.key
$ sudo openssl req -new -key nextcloud.key -out nextcloud.csr
$ sudo openssl x509 -req -days 365 -in nextcloud.csr -signkey nextcloud.key -out nextcloud.crt

也可使用免费的 let encrypt,创建Nginx server block文件:

$ sudo vim /etc/nginx/sites-available/nextcloud

server {
    listen 80;
    server_name pan.csxiaoyao.com;
    return 301 https: //$server_name$request_uri;
}
server {
    listen 443 ssl http2;
    server_name pan.csxiaoyao.com;
    root /
    var / www / nextcloud;
    ssl on;
    ssl_certificate / etc / nginx / ssl / nextcloud.crt;
    ssl_certificate_key / etc / nginx / ssl / nextcloud.key;
    ssl_session_timeout 5m;
    ssl_ciphers 'AES128+EECDH:AES128+EDH:!aNULL';
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_prefer_server_ciphers on;
    add_header X - Content - Type - Options nosniff;
    add_header X - Frame - Options "SAMEORIGIN";
    add_header X - XSS - Protection "1; mode=block";
    add_header X - Robots - Tag none;
    add_header X - Download - Options noopen;
    add_header X - Permitted - Cross - Domain - Policies none;
    access_log /
    var / log / nginx / nextcloud.access.log;
    error_log /
    var / log / nginx / nextcloud.error.log;
    location = /robots.txt {
        allow all;
        log_not_found off;
        access_log off;
    }
    location = /.well - known / carddav {
        return 301 $scheme: //$host/remote.php/dav; 
    }
    location = /.well-known/caldav {
        return 301 $scheme: //$host/remote.php/dav; 
    }
    client_max_body_size 512M;
    fastcgi_buffers 64 4K;
    gzip off;
    error_page 403 / core / templates / 403.php;
    error_page 404 / core / templates / 404.php;
    location / {
        rewrite ^ /index.php$uri;
    }
    location ~ ^/ ( ? : build | tests | config | lib | 3rdparty | templates | data) / {
        deny all;
    }
    location~ ^ /(?:.|autotest|occ|issue|indie|db_|console) {
        deny all;
    }
    location ~^/ ( ? : index | remote | public | cron | core / ajax / update | status | ocs / v[12] | updater / . + | ocs - provider / . + | core / templates / 40[34]).php( ? : $ | /) {
        include fastcgi_params;
        fastcgi_split_path_info ^(.+.php)(/. + ) $;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_param PATH_INFO $fastcgi_path_info;
        fastcgi_param HTTPS on;#
        Avoid sending the security headers twice
        fastcgi_param modHeadersAvailable true;
        fastcgi_param front_controller_active true;
        fastcgi_pass unix: /var/run / php / php7.0 - fpm.sock;
        fastcgi_intercept_errors on;
        fastcgi_request_buffering off;
    }
    location~ ^ /(?:updater|ocs-provider)(?:$|/) {
        try_files $uri / = 404;
        index index.php;
    }
    location~ * .( ? : css | js) $ {
        try_files $uri / index.php$uri$is_args$args;
        add_header Cache - Control "public, max-age=7200";
        add_header X - Content - Type - Options nosniff;
        add_header X - Frame - Options "SAMEORIGIN";
        add_header X - XSS - Protection "1; mode=block";
        add_header X - Robots - Tag none;
        add_header X - Download - Options noopen;
        add_header X - Permitted - Cross - Domain - Policies none;#
        Optional: Don 't log access to assets
        access_log off;
    }
    location ~* .(?:svg|gif|png|html|ttf|woff|ico|jpg|jpeg)$ {
        try_files $uri /index.php$uri$is_args$args;
        access_log off;
    }
    location ~ /.ht {
        deny all;
    }
}

创建链接:

$ sudo ln -s /etc/nginx/sites-available/nextcloud /etc/nginx/sites-enabled/nextcloud

测试Nginx配置文件:

$ sudo nginx -t

重启nginx:

$ sudo systemctl restart nginx

卸载openjdk:

sudo apt-get remove openjdl*;

发表评论

电子邮件地址不会被公开。 必填项已用*标注