uWSGI + Nginx 部署

2024-04-30 14:32
文章标签 部署 nginx uwsgi

本文主要是介绍uWSGI + Nginx 部署,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

uWSGI + Nginx 部署 Flask Web 应用

创建Flask工程

 

这里就用最简单的HelloWorld,创建一个工程目录:linuxidc,里面包含以下文件:

 

文件名:linuxidc.py

 

代码:

 

from flask import Flask

 

app = Flask(__name__)

 

@app.route('/')

 

def hello():

 

    return 'Hello World'

 

if __name__ == '__main__':

 

      app.run()

 

给项目目录配置权限,nginxuwsgi默认是以www-data用户和组来运行:

 chown -R www-data:www-data /var/virenvs/myenv/myproject

 chmod -R 775 /var/virenvs/myenv/myproject

 创建uwsgi配置文件

 

3)配置 uwsgi

 

在刚才创建的linuxidc目录下创建一个uwsgixml配置文件linuxidc_config.xml:

 

<uwsgi>

 

    <pythonpath>[你的工程的根目录]</pythonpath>

 

    <module>[模块名,这里用linuxidc]</module>

 

    <callable>[因为app是启动整个服务的入口,所以是app]</callable>

 

    <socket>0.0.0.0:8000</socket>      #注: 指定某个固定端口

 

    <master/>

 

    <processes>4</processes>                #注:跑几个进程,这里用4个进程

 

    <memory-report/>

 

</uwsgi>

 

4)配置 nginx

 

/etc/nginx/sites-available/目录下,创建一个站点文件:site

 

server {

        listen 80;

        server_name www.linuxidc.com;

 

        location / {

                include uwsgi_params;

                uwsgi_pass  0.0.0.0:8000;  #注:这里的端口8000uwsgi的里配的是同一个端口,因为nginxuwsgi需要通过这个端口进行交互

        }

 }

 

然后用Linuxln命令创建一个link/etc/nginx/sites-enable/里,link的名字也叫site,删除sites-enable目录下的defaultlink。(很重要)

 

5)开始部署

 

启动uwsgi,命令是 sudo uwsgi -x linuxidc_config.xml,会打出很多的字,如果没有加载工程成功可以从打出的信息中看出,然后不要关闭该Terminal,新打开一个Terminal,在里面启动nginxsudo /etc/init.d/nginx start,然后在浏览器里访问localhost就可以看到“Hello World” 

http://my.oschina.net/guol/blog/121418

基于python的web项目,常见的部署方法有:
      fcgi:用spawn-fcgi或者框架自带的工具对各个project分别生成监听进程,然后和http服务互动。
      wsgi:利用http服务的mod_wsgi模块来跑各个project。

不过还有个uwsgi,它既不用wsgi协议也不用fcgi协议,而是自创了一个uwsgi的协议,据作者说该协议大约是fcgi协议的10倍那么快。uWSGI的主要特点如下:
       超快的性能。
       低内存占用(实测为apache2的mod_wsgi的一半左右)。
       多app管理。
       详尽的日志功能(可以用来分析app性能和瓶颈)。
       高度可定制(内存大小限制,服务一定次数后重启等)。

环境ubuntu 12.04 IP:10.1.6.79

安装nginx

1

apt-getinstall nginx-full nginx-common

nginx配置/etc/nginx/sites-enabled/example

1

2

3

4

5

6

7

8

9

10

11

12

13

server {

        listen          80;

        server_name     10.1.6.79;##浏览器访问

        access_log     /var/log/nginx/example_access.log;

        error_log      /var/log/nginx/example_error.log;

        root           /var/www/example;

        location / {

            uwsgi_pass      127.0.0.1:9001; ###uwsgi_pass uwsgi通信

            include         uwsgi_params;

            uwsgi_param     UWSGI_SCHEME $scheme;

            uwsgi_param     SERVER_SOFTWARE    nginx/$nginx_version;

        }

}

安装uwsgi

 

1

apt-getinstall uwsgi uwsgi-plugin-python

    如果你想安装所有的uwsgi插件,则可以安装uwsgi-plugin-all软件包

uwsgi配置/etc/uwsgi/apps-enabled/default.xml

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

<uwsgi>

    <plugin>python</plugin>

    <socket>127.0.0.1:9001</socket> ###uwsgi_pass nigix通信 

    <pythonpath>/var/www/example/app/</pythonpath>

    <app mountpoint="/">

        <script>wsgi_configuration_module</script>

    </app>

    <master/>

    <processes>4</processes>

    <reload-mercy>8</reload-mercy>

    <cpu-affinity>1</cpu-affinity>

    <max-requests>2000</max-requests>

    <limit-as>512</limit-as>

    <reload-on-as>256</reload-on-as>

    <reload-on-rss>192</reload-on-rss>

    <no-orphans/>

    <vacuum/>

</uwsgi>

    uwsgi配置文件中的参数也可以在命令行通过uwsgi指定,配置文件除了xml格式外,还可以写成ini格式的,软件包安装完毕后在/usr/share/doc/uwsgi/examples/conffile目录下会有一些xml和ini格式配置文件的例子。

wsgi_configuration_module.py脚本内容

1

2

3

4

5

6

7

8

9

10

11

12

#!/usr/bin/python

importos

importsys

sys.path.append('/var/www/example/app')

os.environ['PYTHON_EGG_CACHE'] ='/var/www/example/.python-egg'

def application(environ, start_response):

    status ='200 OK'

    output ='Hello World!'

    response_headers = [('Content-type','text/plain'),

                    ('Content-Length', str(len(output)))]

    start_response(status, response_headers)

    return[output]

启动uwsgi

 

1

uwsgi -x/etc/uwsgi/apps-enabled/default.xml --daemonize/var/log/uwsgi/app/default.log

uwsgi 的参数: 
    -M 开启Master进程 
    -p 4 开启4个进程 
    -s 使用的端口或者socket地址 
    -d 使用daemon的方式运行, 注意, 使用-d后, 需要加上log文件地址, 比如-d /var/log/uwsgi.log 
    -R 10000 开启10000个进程后, 自动respawn下 
    -t 30 设置30s的超时时间, 超时后, 自动放弃该链接 
    –limit-as 32 将进程的总内存量控制在32M 
    -x  使用配置文件模式

并发4个线程
uwsgi -s :9090 -w myapp -p 4
主控制线程+4个线程
uwsgi -s :9090 -w myapp -M -p 4
执行超过30秒的client直接放弃
uwsgi -s :9090 -w myapp -M -p 4 -t 30
限制内存空间128M
uwsgi -s :9090 -w myapp -M -p 4 -t 30 --limit-as 128
服务超过10000个req自动respawn
uwsgi -s :9090 -w myapp -M -p 4 -t 30 --limit-as 128 -R 10000
后台运行等
uwsgi -s :9090 -w myapp -M -p 4 -t 30 --limit-as 128 -R 10000 -d uwsgi.log 

      除了直接用uwsgi命令启动外,还可以用init.d下的脚本启动,不过需先修改/etc/default/uwsgi中默认配置文件的路径,然后通过/etc/init.d/uwsgi start启动

 

1

2

#INHERITED_CONFIG=/usr/share/uwsgi/conf/default.ini

INHERITED_CONFIG=/etc/uwsgi/apps-enabled/default.xml

启动nginx

 

1

/etc/init.d/nginxstart

效果如下:


    python在国内用来做web还不多,虽然python也有一些web框架,不过目前来看文档缺失、本身系统的稳定都还没经过量和时间的考验,要像PHP那样大规模的火起来还需一段时间。

 

####################################################################

 

Nginx+uWsgi+web.py 搭建与简单测试

 

 

 

         

Nginx+uWsgi+web.py 搭建与简单测试

Nginx + uWsgi + web.py 效率真是不错。

安装uWsgi  

首先是下载 http://projects.unbit.it/downloads/uwsgi-1.9.14.tar.gz

解压 sudo python setup.py build

安装 make

nginxweb.py的安装就不多说

nginx配置

location / {

include uwsgi_params;

#uwsgi_pass 127.0.0.1:9002;

 #对应uwsgi.ini配置的socket文件

uwsgi_pass unix:/tmp/uwsgi.sock;

}

#静态文件访问

location /static/ {

if (-f $request_filename) {

rewrite ^/static/(.*)$ /static/$1 break;

}

}

基于web.py的脚本index.py

import web

urls = ("/.*", "hello")

app = web.application(urls, globals())

class hello:

def GET(self):

return 'Hello, world!'

#if __name__ == "__main__": #注意将改行注释掉

application = app.wsgifunc()

uWsgi的配置

[uwsgi]

#socket = 127.0.0.1:9002

#socket文件方式

socket = /tmp/uwsgi.sock

chdir = /data/www/webpy/

processes = 8

threads = 2

master = true

module = index

;pidfile = /data/uwsgi-bin/uwsgi.pid

;listen = 128

#守护进程方式运行,并指明日志文件

daemonize = /data/www/webpy/uwsgi.log

注意chdir指向程序目录,module是主运行文件,见上,加入pidfile后好像对性能有影响,所以这里注释掉。

运行 sudo uwsgi uwsgi.ini

测试
   测试使用的是apacheab工具。ab -n1000 -c100 http://192.168.1.1:8080/,结果如下: 

php来测试下,同样的服务器,同样的nginx,使用的是nginx + php-fpm fastcgi的模式。

看得出比PHP还是快了不少

 

 

 #!/bin/bash 

 wget -c http://rfyiamcool.googlecode.com/files/pcre-8.13.tar.gz 

 tar zxvf pcre-8.13.tar.gz 

 cd pcre-8.13/ 

 ./configure 

 make && make install 

 cd ../ 

 useradd www 

 wget -c http://rfyiamcool.googlecode.com/files/nginx-1.2.0.tar.gz 

 tar zxvf nginx-1.2.0.tar.gz 

 cd nginx-1.2.0 

 ./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_gzip_static_module --with-ipv6 

 make && make install 

 cd .. 

 wget http://projects.unbit.it/downloads/uwsgi-latest.tar.gz 

 cd uwsgi-1.3/ 

 python uwsgiconfig.py --build 

 \cp nginx/uwsgi_params /usr/local/nginx/conf/ -f 

  

 vi /usr/local/nginx/conf/nginx.conf 

  

 server { 

         listen        80; 

         server_name localhost; 

  

         location / { 

             root  /usr/local/nginx/html; 

             include uwsgi_params; 

             uwsgi_pass 127.0.0.1:8000; 

         } 

  

  } 

  

 /usr/local/nginx/sbin/nginx 

  

 cd /usr/local/nginx/html 

 vi uwsgi.xml 

 <uwsgi> 

 <socket>127.0.0.1:8000</socket> 

 <module>myuwsgi</module> 

 <master /> 

 <pythonpath>/usr/local/nginx/html</pythonpath> 

 <processes>2</processes> 

 </uwsgi> 

  

 vi   web.py 

  

 #!/usr/bin/env python 

  

 import os 

 import web 

  

 urls = ('/(.*)', 'hello') 

  

 app = web.application(urls, globals()) 

  

 class hello: 

     def GET(self, name): 

         if not name: 

             name = "World" 

         return "Hello" + name + "!" 

  

 appapplication = app.wsgifunc() 

  

  

 启动 

 /usr/local/uwsgi-1.3/uwsgi -x /usr/local/nginx/html/uwsgi.xml --daemonize /usr/local/nginx/html/uwsgi.error.log 

  

  

 停止uWSGI 

  

 killall -9 uwsgi 

  

  

 排错 

 netstat -an|grep -E '(8000|80)' 

 ps aux|grep uwsgi 

http://my.oschina.net/guol/blog/121418

基于python的web项目,常见的部署方法有:
      fcgi:用spawn-fcgi或者框架自带的工具对各个project分别生成监听进程,然后和http服务互动。
      wsgi:利用http服务的mod_wsgi模块来跑各个project。

不过还有个uwsgi,它既不用wsgi协议也不用fcgi协议,而是自创了一个uwsgi的协议,据作者说该协议大约是fcgi协议的10倍那么快。uWSGI的主要特点如下:
       超快的性能。
       低内存占用(实测为apache2的mod_wsgi的一半左右)。
       多app管理。
       详尽的日志功能(可以用来分析app性能和瓶颈)。
       高度可定制(内存大小限制,服务一定次数后重启等)。

环境ubuntu 12.04 IP:10.1.6.79

安装nginx

1

apt-getinstall nginx-full nginx-common

nginx配置/etc/nginx/sites-enabled/example

1

2

3

4

5

6

7

8

9

10

11

12

13

server {

        listen          80;

        server_name     10.1.6.79;##浏览器访问

        access_log     /var/log/nginx/example_access.log;

        error_log      /var/log/nginx/example_error.log;

        root           /var/www/example;

        location / {

            uwsgi_pass      127.0.0.1:9001; ###uwsgi_pass uwsgi通信

            include         uwsgi_params;

            uwsgi_param     UWSGI_SCHEME $scheme;

            uwsgi_param     SERVER_SOFTWARE    nginx/$nginx_version;

        }

}

安装uwsgi

 

1

apt-getinstall uwsgi uwsgi-plugin-python

    如果你想安装所有的uwsgi插件,则可以安装uwsgi-plugin-all软件包

uwsgi配置/etc/uwsgi/apps-enabled/default.xml

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

<uwsgi>

    <plugin>python</plugin>

    <socket>127.0.0.1:9001</socket> ###uwsgi_pass nigix通信 

    <pythonpath>/var/www/example/app/</pythonpath>

    <app mountpoint="/">

        <script>wsgi_configuration_module</script>

    </app>

    <master/>

    <processes>4</processes>

    <reload-mercy>8</reload-mercy>

    <cpu-affinity>1</cpu-affinity>

    <max-requests>2000</max-requests>

    <limit-as>512</limit-as>

    <reload-on-as>256</reload-on-as>

    <reload-on-rss>192</reload-on-rss>

    <no-orphans/>

    <vacuum/>

</uwsgi>

    uwsgi配置文件中的参数也可以在命令行通过uwsgi指定,配置文件除了xml格式外,还可以写成ini格式的,软件包安装完毕后在/usr/share/doc/uwsgi/examples/conffile目录下会有一些xml和ini格式配置文件的例子。

wsgi_configuration_module.py脚本内容

1

2

3

4

5

6

7

8

9

10

11

12

#!/usr/bin/python

importos

importsys

sys.path.append('/var/www/example/app')

os.environ['PYTHON_EGG_CACHE'] ='/var/www/example/.python-egg'

def application(environ, start_response):

    status ='200 OK'

    output ='Hello World!'

    response_headers = [('Content-type','text/plain'),

                    ('Content-Length', str(len(output)))]

    start_response(status, response_headers)

    return[output]

启动uwsgi

 

1

uwsgi -x/etc/uwsgi/apps-enabled/default.xml --daemonize/var/log/uwsgi/app/default.log

uwsgi 的参数: 
    -M 开启Master进程 
    -p 4 开启4个进程 
    -s 使用的端口或者socket地址 
    -d 使用daemon的方式运行, 注意, 使用-d后, 需要加上log文件地址, 比如-d /var/log/uwsgi.log 
    -R 10000 开启10000个进程后, 自动respawn下 
    -t 30 设置30s的超时时间, 超时后, 自动放弃该链接 
    –limit-as 32 将进程的总内存量控制在32M 
    -x  使用配置文件模式

并发4个线程
uwsgi -s :9090 -w myapp -p 4
主控制线程+4个线程
uwsgi -s :9090 -w myapp -M -p 4
执行超过30秒的client直接放弃
uwsgi -s :9090 -w myapp -M -p 4 -t 30
限制内存空间128M
uwsgi -s :9090 -w myapp -M -p 4 -t 30 --limit-as 128
服务超过10000个req自动respawn
uwsgi -s :9090 -w myapp -M -p 4 -t 30 --limit-as 128 -R 10000
后台运行等
uwsgi -s :9090 -w myapp -M -p 4 -t 30 --limit-as 128 -R 10000 -d uwsgi.log 

      除了直接用uwsgi命令启动外,还可以用init.d下的脚本启动,不过需先修改/etc/default/uwsgi中默认配置文件的路径,然后通过/etc/init.d/uwsgi start启动

 

1

2

#INHERITED_CONFIG=/usr/share/uwsgi/conf/default.ini

INHERITED_CONFIG=/etc/uwsgi/apps-enabled/default.xml

启动nginx

 

1

/etc/init.d/nginxstart

效果如下:


    python在国内用来做web还不多,虽然python也有一些web框架,不过目前来看文档缺失、本身系统的稳定都还没经过量和时间的考验,要像PHP那样大规模的火起来还需一段时间。

 

####################################################################

 

Nginx+uWsgi+web.py 搭建与简单测试

 

 

 

         

Nginx+uWsgi+web.py 搭建与简单测试

Nginx + uWsgi + web.py 效率真是不错。

安装uWsgi  

首先是下载 http://projects.unbit.it/downloads/uwsgi-1.9.14.tar.gz

解压 sudo python setup.py build

安装 make

nginxweb.py的安装就不多说

nginx配置

location / {

include uwsgi_params;

#uwsgi_pass 127.0.0.1:9002;

 #对应uwsgi.ini配置的socket文件

uwsgi_pass unix:/tmp/uwsgi.sock;

}

#静态文件访问

location /static/ {

if (-f $request_filename) {

rewrite ^/static/(.*)$ /static/$1 break;

}

}

基于web.py的脚本index.py

import web

urls = ("/.*", "hello")

app = web.application(urls, globals())

class hello:

def GET(self):

return 'Hello, world!'

#if __name__ == "__main__": #注意将改行注释掉

application = app.wsgifunc()

uWsgi的配置

[uwsgi]

#socket = 127.0.0.1:9002

#socket文件方式

socket = /tmp/uwsgi.sock

chdir = /data/www/webpy/

processes = 8

threads = 2

master = true

module = index

;pidfile = /data/uwsgi-bin/uwsgi.pid

;listen = 128

#守护进程方式运行,并指明日志文件

daemonize = /data/www/webpy/uwsgi.log

注意chdir指向程序目录,module是主运行文件,见上,加入pidfile后好像对性能有影响,所以这里注释掉。

运行 sudo uwsgi uwsgi.ini

测试
   测试使用的是apacheab工具。ab -n1000 -c100 http://192.168.1.1:8080/,结果如下: 

php来测试下,同样的服务器,同样的nginx,使用的是nginx + php-fpm fastcgi的模式。

看得出比PHP还是快了不少

 

 

 #!/bin/bash 

 wget -c http://rfyiamcool.googlecode.com/files/pcre-8.13.tar.gz 

 tar zxvf pcre-8.13.tar.gz 

 cd pcre-8.13/ 

 ./configure 

 make && make install 

 cd ../ 

 useradd www 

 wget -c http://rfyiamcool.googlecode.com/files/nginx-1.2.0.tar.gz 

 tar zxvf nginx-1.2.0.tar.gz 

 cd nginx-1.2.0 

 ./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_gzip_static_module --with-ipv6 

 make && make install 

 cd .. 

 wget http://projects.unbit.it/downloads/uwsgi-latest.tar.gz 

 cd uwsgi-1.3/ 

 python uwsgiconfig.py --build 

 \cp nginx/uwsgi_params /usr/local/nginx/conf/ -f 

  

 vi /usr/local/nginx/conf/nginx.conf 

  

 server { 

         listen        80; 

         server_name localhost; 

  

         location / { 

             root  /usr/local/nginx/html; 

             include uwsgi_params; 

             uwsgi_pass 127.0.0.1:8000; 

         } 

  

  } 

  

 /usr/local/nginx/sbin/nginx 

  

 cd /usr/local/nginx/html 

 vi uwsgi.xml 

 <uwsgi> 

 <socket>127.0.0.1:8000</socket> 

 <module>myuwsgi</module> 

 <master /> 

 <pythonpath>/usr/local/nginx/html</pythonpath> 

 <processes>2</processes> 

 </uwsgi> 

  

 vi   web.py 

  

 #!/usr/bin/env python 

  

 import os 

 import web 

  

 urls = ('/(.*)', 'hello') 

  

 app = web.application(urls, globals()) 

  

 class hello: 

     def GET(self, name): 

         if not name: 

             name = "World" 

         return "Hello" + name + "!" 

  

 appapplication = app.wsgifunc() 

  

  

 启动 

 /usr/local/uwsgi-1.3/uwsgi -x /usr/local/nginx/html/uwsgi.xml --daemonize /usr/local/nginx/html/uwsgi.error.log 

  

  

 停止uWSGI 

  

 killall -9 uwsgi 

  

  

 排错 

 netstat -an|grep -E '(8000|80)' 

 ps aux|grep uwsgi 

这篇关于uWSGI + Nginx 部署的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/949121

相关文章

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

SpringBoot配置Ollama实现本地部署DeepSeek

《SpringBoot配置Ollama实现本地部署DeepSeek》本文主要介绍了在本地环境中使用Ollama配置DeepSeek模型,并在IntelliJIDEA中创建一个Sprin... 目录前言详细步骤一、本地配置DeepSeek二、SpringBoot项目调用本地DeepSeek前言随着人工智能技

如何自定义Nginx JSON日志格式配置

《如何自定义NginxJSON日志格式配置》Nginx作为最流行的Web服务器之一,其灵活的日志配置能力允许我们根据需求定制日志格式,本文将详细介绍如何配置Nginx以JSON格式记录访问日志,这种... 目录前言为什么选择jsON格式日志?配置步骤详解1. 安装Nginx服务2. 自定义JSON日志格式各

通过Docker Compose部署MySQL的详细教程

《通过DockerCompose部署MySQL的详细教程》DockerCompose作为Docker官方的容器编排工具,为MySQL数据库部署带来了显著优势,下面小编就来为大家详细介绍一... 目录一、docker Compose 部署 mysql 的优势二、环境准备与基础配置2.1 项目目录结构2.2 基

CentOS 7部署主域名服务器 DNS的方法

《CentOS7部署主域名服务器DNS的方法》文章详细介绍了在CentOS7上部署主域名服务器DNS的步骤,包括安装BIND服务、配置DNS服务、添加域名区域、创建区域文件、配置反向解析、检查配置... 目录1. 安装 BIND 服务和工具2.  配置 BIND 服务3 . 添加你的域名区域配置4.创建区域

Nginx指令add_header和proxy_set_header的区别及说明

《Nginx指令add_header和proxy_set_header的区别及说明》:本文主要介绍Nginx指令add_header和proxy_set_header的区别及说明,具有很好的参考价... 目录Nginx指令add_header和proxy_set_header区别如何理解反向代理?proxy

OpenManus本地部署实战亲测有效完全免费(最新推荐)

《OpenManus本地部署实战亲测有效完全免费(最新推荐)》文章介绍了如何在本地部署OpenManus大语言模型,包括环境搭建、LLM编程接口配置和测试步骤,本文给大家讲解的非常详细,感兴趣的朋友一... 目录1.概况2.环境搭建2.1安装miniconda或者anaconda2.2 LLM编程接口配置2

Nginx配置location+rewrite实现隐性域名配置

《Nginx配置location+rewrite实现隐性域名配置》本文主要介绍了Nginx配置location+rewrite实现隐性域名配置,包括基于根目录、条件和反向代理+rewrite配置的隐性... 目录1、配置基于根目录的隐性域名(就是nginx反向代理)2、配置基于条件的隐性域名2.1、基于条件

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架