【问题标题】:Permission denied when running redis via java on mac在mac上通过java运行redis时权限被拒绝
【发布时间】:2015-09-13 05:25:09
【问题描述】:

我正在使用嵌入式redis项目https://github.com/kstyrc/embedded-redis 试图通过我的单元测试运行它。我在mac机器上。

我的 redis impl 位于目录:/Users/myname/servers/redis-unstable

只要我尝试运行它:

@Before
    public void init() throws IOException {     
        redisServer = new RedisServer(new File("/Users/myname/servers/redis-unstable"), 6379);   
        redisServer.start();
    }

我的权限被拒绝:

redis.embedded.exceptions.EmbeddedRedisException: Failed to start Redis instance
    at redis.embedded.AbstractRedisInstance.start(AbstractRedisInstance.java:42)
    at redis.embedded.RedisServer.start(RedisServer.java:9)
    at com.zone.world_map_service_web.LocationServiceTest.init(LocationServiceTest.java:38)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:24)
    at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
    at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
    at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:78)
    at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:212)
    at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:68)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:140)
Caused by: java.io.IOException: Cannot run program "/Users/myname/servers/redis-unstable" (in directory "/Users/myname/servers"): error=13, Permission denied
    at java.lang.ProcessBuilder.start(ProcessBuilder.java:1048)
    at redis.embedded.AbstractRedisInstance.start(AbstractRedisInstance.java:37)
    ... 29 more
Caused by: java.io.IOException: error=13, Permission denied
    at java.lang.UNIXProcess.forkAndExec(Native Method)
    at java.lang.UNIXProcess.<init>(UNIXProcess.java:248)
    at java.lang.ProcessImpl.start(ProcessImpl.java:134)
    at java.lang.ProcessBuilder.start(ProcessBuilder.java:1029)
    ... 30 more

我什么都试过了.. chmod 755 chmod u+x

还是一样的错误。

有什么想法吗?

【问题讨论】:

    标签: java macos unix junit redis


    【解决方案1】:

    你下载后是否运行过make命令?我认为即使它是不稳定的版本,你也会寻找 redis-server 而不是 redis-unstable。

    【讨论】:

    • redis-unstable 工作得很好,我可以使用它。我刚刚通过这个java单元测试过程执行它时遇到了这个权限问题
    • 我可能说错了,我相信 redis-server 的可执行文件总是被称为 redis-server 无论版本如何(除非你重命名它)。我在 ..../redis-unstable/src/redis-server 下找到可执行文件。
    • 这是关于 mac 上的权限,我不知道如何克服它们
    • 您的代码以什么用户身份运行?你可以'su - codeRunningUser'然后尝试通过命令行运行redis服务器吗?
    猜你喜欢
    • 1970-01-01
    • 2012-08-29
    • 2021-09-04
    • 1970-01-01
    • 2021-06-11
    • 1970-01-01
    • 1970-01-01
    • 2020-05-13
    • 1970-01-01
    相关资源
    最近更新 更多