Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

preloading jobe (or jobeinabox maybe) with some files #62

Closed
gigamonkey opened this issue Jun 25, 2023 · 6 comments
Closed

preloading jobe (or jobeinabox maybe) with some files #62

gigamonkey opened this issue Jun 25, 2023 · 6 comments

Comments

@gigamonkey
Copy link
Contributor

Hi, hope this is an okay place to ask this kind of question.

I'm looking it using jobe to run Java programs for a web-based programming environment. If there are certain jar files that I know I'm going to want to make available to javac and java is there a standard way to preload them into the environment other than having the client upload them into the filecache via the REST API?

Hope that question actually makes sense; I've only been poking around and reading docs for a day or so so I obviously may have missed something obvious or misunderstood something. Cheers!

@trampgeek
Copy link
Owner

trampgeek commented Jun 25, 2023

When you say "into the environment", do you mean "into the temporary working directory for the run"? If so, then the short answer is probably no, since the only files that get loaded into that directory need to be loaded from the filecache, by their unique ID. However, you could have Jobe run a Python script/program instead of a Java program; the script could set up the environment, copying files from anywhere you choose to put them in Jobe, then compile and run the Java code using the subprocess module. That gives you complete flexibility for other tasks like pre-run checks on the Java code, setting up a directory tree for packages, etc.

But do your jar files need to be in the current working directory? Could you not put them in a fixed part of the file system, say /usr/local/share, and refer to them with a full path name?

@gigamonkey
Copy link
Contributor Author

When I asked the question I think I meant "into the temporary working directory" but my understanding was more fuzzy than it is now—I got jobe running in Docker and ran a few test jobs last night. And indeed they don't need to be in the current working directory—my whole idea was to have a set of classes that a lot of jobs would need access to so the nicest thing would be to have one copy on the jobe server that jobs could add to their classpath as needed.

I guess I had assumed that the individual jobs were running in a chroot jail or something and therefore wouldn't be able to access arbitrary files. But maybe that's not the case?

@trampgeek
Copy link
Owner

Jobe tasks run as normal unprivileged users on a Linux system except there's no home directory and there are tight limits on resource usage, such as cpuseconds, number of processes, disk output, memory use, .... The working directory in which they run is inaccessible to all other users - there's one user per task.

@gigamonkey
Copy link
Contributor Author

Ah got it. Now that you say it I feel like I read that sentence somewhere in the docs but it didn't quite sink in. And I assume the users who run the jobs don't have privileges to write outside their working directory so they can't scribble over anything important?

@trampgeek
Copy link
Owner

Correct. They have minimal access to anything else except /tmp, which is purged after the run. Unless a sysadmin chooses to create world-writeable directories.

@gigamonkey
Copy link
Contributor Author

Thanks for you help. Closing this to keep you project tidy. Cheers!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants