百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Mac 基于HTTP方式访问下载共享文件,配置共享服务器

wptr33 2025-01-21 21:58 29 浏览

方法一:使用Python的SimpleHTTPServer进行局域网文件共享

Mac 自带Python,所以不需要安装其他软件,一条命令即可

1):进入需要共享的文件夹,如Public文件夹

cd /Users/test/Public

2):启动局域网共享

后面可加端口,如不加80端口,默认为8000端口

sudo python -m SimpleHTTPServer 80

在浏览器访问 ip:端口,可查看文件

优点:简单

缺点:文件显示简单,没有详细信息,界面不友好


方法二:搭建apache ftp server 服务器

1):需要搭建Java环境

  • 1.1下载Java JDK安装

下载地址https://www.oracle.com/java/technologies/downloads/

选择macOS 下载,在电脑上安装即可。

  • 1.2 配置java环境

进入跟目录,创建或编辑 .bash_profile文件,

cd /
vi .bash_profile

内容如下:

JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk-17.jdk/Contents/Home/
CLASSPAHT=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
PATH=$JAVA_HOME/bin:$PATH:
export JAVA_HOME
export CLASSPATH
export PATH

编辑完成后,刷新配置文件

source .bash_profile

配置完成,输入`echo $JAVA_HOME`,可查看刚才配置环境

test@testdeMac ~ % echo $JAVA_HOME
/Library/Java/JavaVirtualMachines/jdk-17.jdk/Contents/Home

至此java环境搭建完成。


2):下载apache ftp server

下载地址:

https://www.apache.org/dyn/closer.lua/mina/ftpserver/1.1.1/dist/apache-ftpserver-1.1.1.tar.gz

  • 终端输入命令下载解压
curl -O https://dlcdn.apache.org/mina/ftpserver/1.1.1/dist/apache-ftpserver-1.1.1.tar.gz
tar zxvf apache-ftpserver-1.1.1.tar.gz
  • 修改用户配置(\apache-ftpserver-1.1.1\res\conf\users.properties),如:需要添加(用户:ftpuser 密码:ftpuser),则在末尾添加
vim apache-ftpserver-1.1.1/res/conf/users.properties

添加用户信息如下:

########### 自定义用户 ##########
#密码
ftpserver.user.ftpuser.userpassword=ftpuser
#主目录(文件上传的根目录)
ftpserver.user.ftpuser.homedirectory=./res/home
#当前用户可用
ftpserver.user.ftpuser.enableflag=true
#是否具有上传权限
ftpserver.user.ftpuser.writepermission=true
#最大登录数为20(如果为0,表示无限制)
ftpserver.user.ftpuser.maxloginnumber=20
#同IP登录用户数为2(如果为0,表示无限制)
ftpserver.user.ftpuser.maxloginperip=2
#空闲时间为300秒(如果为0,表示无限制)
ftpserver.user.ftpuser.idletime=300
#上传速率限制为480000字节每秒(如果为0,表示无限制)
ftpserver.user.ftpuser.uploadrate=4800
#下载速率限制为480000字节每秒(如果为0,表示无限制)
ftpserver.user.ftpuser.downloadrate=4800
  • 修改服务器配置信息,如端口,默认为2121
vim apache-ftpserver-1.1.1/res/conf/ftpd-typical.xml
  • 启动,修改完成后,进入apache-ftpserver-1.1.1/bin目录
cd apache-ftpserver-1.1.1/bin

启动ftp服务器:

./ftpd.sh res/conf/ftpd-typical.xml

提示以下信息,启动成功:

Using XML configuration file res/conf/ftpd-typical.xml...

FtpServer started

3):浏览器输入ftp://IP:端口测试

这里测试IP为: ftp://192.168.152.180:2121/ ,浏览器输入即可

或者在“我的电脑” 地址栏,输入测试。

搭建完成,文件保存路径为:apache-ftpserver-1.1.1/res/home/

优点:支持文件资源管理器和浏览器查看下载,上传在客户端也可以。

缺点:浏览器支持不多,老版IE和火狐支持,最新版浏览器,如谷歌,已不支持ftp界面显示


方法三:搭建nginx服务器,配置文件管理(推荐)

mac无法直接安装nginx,需下载Homebrew工具包安装。

1):安装Homebrew

官网:https://brew.sh/

按照命令安装

/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"

按提示输入管理员密码,和回车键即可。

2):安装nginx

brew install nginx

安装完成

3):配置nginx共享配置文件

进入nginx配置文件夹,新建共享文件sharefile.conf

cd /usr/local/etc/nginx/servers

输入以下内容

server {
	listen 80;
	server_name localhost;

location / {
	root /; #共享文件目录位置
	#index index.html index.htm;
	autoindex on; #--- 开启nginx站点目录索引功能
	#auth_basic "pass";
	#auth_basic_user_file password/htpasswd;
	}
}

其他参数参考

autoindex on; #开启nginx目录浏览功能
autoindex_exact_size off; #文件大小从KB开始显示
autoindex_localtime on; #显示文件修改时间为服务器本地时间

最后启动nginx即可访问,输入nginx即可启动

nginx

如果更改配置文件后,重载配置文件即可

nginx -s reload

最后浏览器输入IP地址即可访问,

这里nginx共享文件搭建完成。

4):配置nginx开机启动

复制启动文件到/Library/LaunchDaemons/

sudo cp /usr/local/opt/nginx/homebrew.mxcl.nginx.plist /Library/LaunchDaemons/

根据自己需求更改配置文件

sudo vim /Library/LaunchDaemons/homebrew.mxcl.nginx.plist

原配置如下

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>homebrew.mxcl.nginx</string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/opt/nginx/bin/nginx</string>
<string>-g</string>
<string>daemon off;</string>
</array>
<key>RunAtLoad</key>
<true/>
<key>WorkingDirectory</key>
<string>/usr/local</string>
</dict>
</plist>

更改后如下,更改两点。

1:删掉daemon off,让默认后台运行。

2:设置Nginx 服务状态是活跃的,加上参数<key>KeepAlive</key><true/>

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>homebrew.mxcl.nginx</string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/opt/nginx/bin/nginx</string>
</array>
<key>KeepAlive</key>
<true/>
<key>RunAtLoad</key>
<true/>
<key>WorkingDirectory</key>
<string>/usr/local</string>
</dict>
</plist>


注册为系统服务,加 sudo 和不加sudo是不同的效果,非root用户启动不加。否则开机启动不生效。

用户根据自己需求看是否添加sudo启动。

launchctl load /Library/LaunchDaemons/com.nginx.plist

非root用户查看是否生效,root用户加sudo查看。

brew services list

如状态Status为start状态,为启动,stop为没有启动。如下图所示

重启电脑后,查看nginx是否启动

ps -ef|grep nginx

启动完成,nginx共享文件完成。

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...